PREMESSA 


A coronamento del “corso” sulla programmazione con linguaggio Assembler dei 
microprocessori serie ST6, non poteva mancare la raccolta in un unico cd-rom di 
tutti gli articoli pubblicati nel corso degli anni sull’argomento. 

E quando diciamo tutti, intendiamo proprio tutti: dai due programmatori in kit, ai 
circuiti di prova, dalla spiegazione teorica delle istruzioni del linguaggio Assem¬ 
bler, alla loro applicazione pratica in elettronica, dagli accorgimenti per utilizzare 
al meglio le istruzioni e la memoria dei micro, all’uso del software emulatore per 
testare i programmi. 

L’intento didattico accompagna tutti gli articoli, anche quelli che, a prima vista, so¬ 
no di carattere più propriamente pratico: gli stessi programmi-sorgente, che tro¬ 
vate in questo stesso cd-rom in una directory dedicata, servono soprattutto per ca¬ 
pire come si deve scrivere un’istruzione per ottenere una determinata funzione. 
Leggendo i commenti accanto ad ogni riga di programma, non solo vi impadro¬ 
nirete della materia, ma potrete addirittura utilizzare blocchi di istruzioni trasfe¬ 
rendoli nei vostri programmi. 

Inoltre, con i software emulatori che vi proponiamo diventa facilissimo controlla¬ 
re le istruzioni via via che vengono eseguite. E’ così possibile capire dove e per¬ 
ché si genera l’errore e come fare per correggerlo. 

Per questo motivo, ci siamo premurati di mettere a vostra disposizione, sempre 
in questo cd-rom, l’ultima versione del software emulatore SimST62, che avete 
imparato a conoscere, ad usare e ad apprezzare nei nostri articoli. 

In appendice trovate il kit di una lampada ad ultravioletti per cancellare i micro- 
processori con memoria Eprom e un inedito sulla funzione Timer dei micropro¬ 
cessori ST6, che tiene conto del fatto che in alcuni tipi di micro è possibile atti¬ 
vare alcune modalità di funzionamento particolari e molto interessanti. 

Non poteva mancare l’indice analitico dei kit e degli argomenti teorici, che vi ri¬ 
manda immediatamente agli articoli in cui l’argomento scelto è trattato. 


la Direzione Editoriale 


Bologna, Gennaio 2003 

Nota: poiché negli articoli si fa spesso riferimento agli argomenti trattati specifi¬ 
cando la rivista in cui sono apparsi, nel sommario abbiamo riportato, oltre al tito¬ 
lo dell’articolo, anche il numero di rivista in cui è stato pubblicato, per facilitarne 
il ritrovamento aH’interno del cd-rom. 
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Molti Istituti Tecnici e non pochi softwaristi e pro¬ 
gettisti ci chiedono con sempre maggiore insi¬ 
stenza di spiegare in modo molto semplice come 
si programmano i microprocessori ST62, ritenendo 
che se ci prendiamo questo impegno lo adempire¬ 
mo come è nostra consuetudine nel migliore dei 
modi. 

Per accontentarvi iniziamo subito dicendo che i mi¬ 
croprocessori della famiglia ST62 sono reperibili in 
due diverse versioni: 

quelli siglati ST62/E e quelli siglati ST62/T. 

La lettera E posta dopo la sigla ST62 indica che il 
microprocessore si può cancellare e riprogram¬ 
mare per almeno un centinaio di volte. 

I microprocessori ST62/E si riconoscono facilmen¬ 
te perché al centro del loro corpo è presente una 
piccola finestra (vedi fig.1) che permette di can¬ 
cellare la EPROM interna tramite una lampada a 
raggi ultravioletti. 

La lettera T, posta dopo la sigla ST62, indica che 
i dati memorizzati all’interno del microprocessore 


Solo quando si ha la conferma che il programma 
funziona regolarmente, si preferisce utilizzare i mi¬ 
croprocessori della serie ST62/T, perché oltre ad 
essere meno costosi, non è più possibile mano¬ 
metterli. 

Nelle Tabelle N.1 e N.2 riportiamo le principali ca¬ 
ratteristiche di queste due serie di microprocessori. 
Tenete presente che nei microprocessori da 2 K di 
memoria è possibile inserire circa 900 - 990 righe 
di programma ed in quelli da 4 K circa 1.800 - 2.000 
righe di programma. 

Per completare i dati riportati nelle due tabelle, pre¬ 
cisiamo che il numero a due cifre riportato dopo la 
sigla, ad esempio ST62E.10 - 15 - 20 - 25, ha un 
preciso significato. 

La prima cifra indica la memoria disponibile: 

- se la prima cifra è un 1 (vedi 10-15) sono dispo¬ 
nibili 2 K di memoria, 


PROGRAMMATORE per 


non si possono più cancellare e quindi nemmeno 
riscrivere. 

Gli ST62/T si riconoscono facilmente perché sono 
sprovvisti della finestra per la cancellazione (ve¬ 
di fig.1). 

Solitamente i microprocessori ST62/E vengono u- 
sati per le prime prove, perché in presenza di un 
eventuale errore nei programmi è sempre possibi¬ 
le cancellare e riscrive il software. 


- se la prima cifra è un 2 (vedi 20-25) sono dispo¬ 
nibili 4 K di memoria. 

La seconda cifra indica i piedini disponibili per i se¬ 
gnali d’ingresso e d’uscita: 

- se la seconda cifra è uno 0 (10-20) sono dispo¬ 
nibili 12 piedini, 

- se la seconda cifra è un 5 (15-25) sono disponi¬ 
bili 20 piedini. 


TABELLA N.1 micro NON CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62T.10 

2 K 

64 byte 

20 pin 

12 

ST62T.15 

2 K 

64 byte 

28 pin 

20 

ST62T.20 

4 K 

64 byte 

20 pin 

12 

ST62T.25 

4 K 

64 byte 

28 pin 

20 


TABELLA N.2 micro CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62E.10 

2 K 

64 byte 

20 pin 

12 

ST62E.15 

2 K 

64 byte 

28 pin 

20 

ST62E.20 

4 K 

64 byte 

20 pin 

12 

ST62E.25 

4 K 

64 byte 

28 pin 

20 























microprocessori serie $T6 


Si parla spesso dei vantaggi che offrono i microprocessori ST62 senza 
però spiegare quello che interessa maggiormente, cioè come fare per 
programmarli e quale programmatore utilizzare. Al contrario noi vi spie¬ 
gheremo come costruirvi un valido programmatore ed anche come si 
deve procedere per programmare questi microprocessori. 


Se osservate la zoccolatura di questi microproces¬ 
sori (vedi fig.2-3), potete leggere a fianco di ogni 
piedino una sigla, e poiché non sempre viene pre¬ 
cisato il loro esatto significato, sarà utile spiegarlo. 

Vcc - Piedino di alimentazione positiva. Su que¬ 
sto piedino va applicata una tensione continua sta¬ 
bilizzata di 5 volt. 

TIMER - Applicando su questo piedino un livello 
logico 1, la frequenza del quarzo (vedi piedini 3- 
4) divisa x12 potrà giungere sullo stadio contato¬ 
re. Da questo piedino è possibile prelevare un se¬ 
gnale ad onda quadra, la cui frequenza può esse¬ 
re stabilita con le istruzioni del programma. 

OSC./ln-Out - Sui piedini 3-4 viene applicato un 
quarzo necessario per avere la frequenza di clock 
che serve per far funzionare il microprocessore. 


NMI - Questo piedino va sempre tenuto a livello 
logico 1. Applicando a questo piedino un impulso 
negativo, si informa la CPU di interrompere il pro¬ 
gramma che sta eseguendo e di passare automa¬ 
ticamente ad eseguire una seconda e diversa 
subroutine (sottoprogramma). 

Vpp - Questo piedino serve per la programmazio¬ 
ne. Durante la fase di programmazione questo pie¬ 
dino, che normalmente si trova a 5 volt, riceve dal 
computer una tensione di 12,5 volt. Quando il mi¬ 
croprocessore già programmato viene inserito nel¬ 
la sua scheda di utilizzazione, si deve sempre te¬ 
nere questo piedino a livello logico 0, per evitare 
di danneggiare i dati in memoria. 

RESET - Questo piedino, che si trova sempre a li¬ 
vello logico 1 , resetta il microprocessore ogni vol¬ 
ta che viene cortocircuitato a massa. Quando si u- 













tilizza un microprocessore già programmato, su ta¬ 
le piedino occorre sempre collegare una resisten¬ 
za al positivo ed un condensatore verso massa, 
in modo da avere un reset automatico ogni volta 
che si alimenta il microprocessore. 

PA - PB - PC - Sono le porte che la CPU può u- 
tilizzare singolarmente come ingressi oppure co¬ 
me uscite tramite programma. Se le utilizzate co¬ 
me uscite, per non danneggiarle è consigliabile 
non collegare dei circuiti che assorbano più di 5 
milliAmpere. Per pilotare dei circuiti che assorbo¬ 
no più di 5 mA, è necessario interporre tra il mi¬ 
croprocessore ed il carico esterno dei transistor 
oppure un integrato tipo SN.74244 o 74HC244 o 
74LS244. 

GND - Piedino di alimentazione da collegare a 

massa. 

SCHEMA ELETTRICO del PROGRAMMATORE 

L’intero circuito programmatore visibile in fig.5 è 
molto semplice perché richiede solo 3 transistor, 
due NPN ed un PNP, due integrati stabilizzatori di 
tensione UA.78L05 (vedi IC2-IC3), un integrato di¬ 
gitale C/Mos tipo SN.74HC14 contenente sei in¬ 
verter a trigger di Schmitt (vedi IC1) ed infine uno 
zoccolo textool a 28 piedini. 

Su questo zoccolo andrà infilato il microprocesso¬ 
re ST62 che si vuole programmare. 

Tutte le tensioni necessarie al microprocessore 
ST62 vengono prelevate dal secondario del tra¬ 
sformatore TI. 

I 15 volt alternati, raddrizzati dal ponte RS1, forni¬ 
scono una tensione continua di circa 20 - 21 volt 
che raggiunge l’Emettitore del transistor PNP si¬ 
glato TR2. 

Come si vede nel disegno dello schema elettrico, 
la Base di questo transistor risulta collegata, tra¬ 
mite la resistenza R3, al Collettore del transistor 
NPN siglato TRI. 

Quando questo transistor riceve dai piedini 2-1 del 
Connettore collegato al computer la necessaria 
tensione di polarizzazione, porta in conduzione il 
transistor TR2 ed in questo modo la tensione po¬ 
sitiva di 20 - 21 volt può raggiungere gli ingressi 
dei due integrati stabilizzatori siglati IC2 - IC3. 
L’integrato IC2 provvede a fornire sulla sua uscita 
una tensione stabilizzata di 5 volt per alimentare 
l’integrato IC1 ed i piedini 1-5 dell’ST62 a 28 pie¬ 
dini o il solo piedino 1 dell’ST62 a 20 piedini. 
L’integrato IC3 provvede a fornire una tensione sta¬ 
bilizzata, sempre di 5 volt, sul piedino 10 dell’ST62 
a 28 piedini o sul piedino 6 dell’ST62 a 20 piedini. 
Quando tramite computer si desidera memorizza¬ 
re un programma aN’interno dell’ST62, il piedino 3 


del Connettore, che normalmente si trova a livel¬ 
lo logico 1 , si commuta sul livello logico 0 e co¬ 
sì la Base del transistor NPN siglato TR3 toglie il 
cortocircuito sul diodo zener DZ1 da 7,5 volt. 

In questo modo la tensione sull’uscita dell’integra¬ 
to stabilizzatore IC3 sale dai 5 volt iniziali a 12,5 
volt (5 + 7,5 = 12,5). 

Da questo istante i dati in scrittura giungono dal 
computer sui terminali 4-6-5-7 del Connettore e, 
prima di raggiungere il microprocessore ST62, 
vengono squadrati dai quattro inverter siglati 
IC1/E - IC1/A - IC1/B - IC1/F. 

Le resistenze R7 - R5 - R6 - R8, che abbiamo po¬ 
sto in serie agli ingressi di questi inverter, servo¬ 
no per proteggerli nell’eventualità che il CONN.1 
venga per errore collegato sulla presa Seriale del 
computer anziché su quella Parallela. 

Poiché non l’abbiamo ancora precisato, vi segna¬ 
liamo fin da ora che il CONN.1 va inserito nella 
PRESA PARALLELA del computer (presa LPT1), 
alla quale è normalmente collegata la stampante. 
A memorizzazione completata, il computer ripor¬ 
ta a livello logico 1 il piedino 3 del CONN.1 pola¬ 
rizzando così la Base del transistor TR3, che por¬ 
tandosi in conduzione, cortocircuita a massa il 
diodo zener DZ1. 

Quando il diodo zener risulta cortocircuitato, sull’u¬ 
scita dell’integrato stabilizzatore IC3 la tensione 
scende da 12,5 a soli 5 volt ed in queste condi- 



Fig.1 I microprocessori della serie ST62/T 
sprovvisti di finestra NON sono cancella¬ 
bili, mentre i microprocessori della serie 
ST62/E disponendo di una piccola finestra 
SONO cancellabili. Il numero posto dopo la 
sigla T o E indica i Kilobyte di memoria e i 
piedini utili per i segnali di entrata e di u- 
scita (vedi Tabelle 1-2). 
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Fig.2 Tutti i microprocessori siglati ST62/E10 e ST62/T10 hanno 2K di memoria utile, men¬ 
tre quelli siglati ST62/E20 e ST62/T20 hanno 4K di memoria utile. Questi microprocesso¬ 
ri a 20 piedini dispongono di 12 porte di entrata o di uscita. La porta A dispone di 4 en¬ 
trate/uscite (PA1-PA2 ecc.), mentre la porta B di 8 entrate/uscite (PB1-PB2 ecc.) 
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Fig.3 Tutti i microprocessori siglati ST62/E15 e ST62/T15 hanno 2K di memoria utile, men¬ 
tre quelli siglati ST62/E25 e ST62/T25 hanno 4K di memoria utile. Questi microprocesso¬ 
ri a 28 piedini dispongono di 28 porte di entrata o di uscita. Le porte A-B dispongono di 
8 entrate/uscite (vedi PAI, PB1), mentre la porta C di 4 entrate/uscite (vedi PCI). 


















































































































zioni nessun dato può più essere trascritto nella 
memoria del microprocessore. 

I due inverter IC1/C - IC1/D, collegati in parallelo 
ed inseriti in senso inverso rispetto agli altri quat¬ 
tro inverter, vengono utilizzati dal computer per leg¬ 
gere i dati dall’ST62. 

Grazie a questa uscita il computer può rileggere 
il programma caricato sul microprocessore e veri¬ 
ficare che non vi siano errori nella trascrizione dei 
dati. 

In presenza di un errore è possibile cancellare il 
microprocessore e ricopiare nella sua memoria i 
dati corretti, a patto che l’integrato inserito nel tex- 
tool sia del tipo ST62/E. 

Nello schema pratico visibile in fig.7 abbiamo raffi¬ 
gurato lo zoccolo textool per i microprocessori con 
28 piedini e non per i microprocessori con 20 pie¬ 
dini, ma come vi spiegheremo più avanti, lo stes¬ 
so zoccolo viene utilizzato per entrambi i micro- 
processori. 

A questo punto possiamo passare alla descrizione 
della realizzazione pratica e subito dopo vi spie¬ 
gheremo come procedere per la memorizzazione 
dei programmi-test che troverete nel dischetto 
floppy fornito assieme al kit. 

Sono inoltre in preparazione degli articoli teorico¬ 
pratici per insegnarvi a scrivere alcuni dei pro¬ 
grammi che possono svolgere i microprocessori 
della serie ST62. 

Vi chiediamo però di concederci un po’ di tempo, 
perché oltre a testare i programmi, vogliamo ricer¬ 
care tutte le possibili soluzioni per renderli com¬ 
prensibili a tutti. 

REALIZZAZIONE PRATICA 

La realizzazione pratica è così semplice che in bre¬ 
vissimo tempo avrete già disponibile il vostro pro¬ 
grammatore montato e funzionante. 

Sul circuito stampato a fori metallizzati siglato 
LX.1170, dovete montare tutti i componenti richie¬ 
sti disponendoli come visibile in fig.7. 

Potete iniziare inserendo e stagnando i piedini de¬ 
gli zoccoli per l’integrato IC1 e per il textool. 
Quest’ultimo deve essere inserito nello stampato 
rivolgendo la leva di bloccaggio verso il basso, co¬ 
me appare chiaramente visibile nello schema pra¬ 
tico di fig.7. 

Dopo questi due componenti potete inserire i due 
diodi: la fascia bianca presente sul corpo plastico 
del diodo siglato DS1 va rivolta verso la resisten¬ 
za R3, mentre la fascia nera presente sul corpo in 
vetro del diodo zener siglato DZ1 va rivolta verso 
l’alto. 

Proseguendo nel montaggio inserite tutte le resi¬ 
stenze, i condensatori poliestere e l’elettrolitico 


ELENCO COMPONENTI LX.1170 

RI = 10.000 ohm 1/4 watt 
R2 = 47.000 ohm 1/4 watt 
R3 = 4.700 ohm 1/4 watt 
R4 = 10.000 ohm 1/4 watt 
R5 = 220 ohm 1/4 watt 
R6 = 220 ohm 1/4 watt 
R7 = 220 ohm 1/4 watt 
R8 = 220 ohm 1/4 watt 
*R9 = 1.500 ohm 1/4 watt 
CI = 22 mF elettr. 25 volt 
C2 = 100.000 pF poliestere 
C3 = 100.000 pF poliestere 
C4 = 100.000 pF poliestere 
C5 = 100.000 pF poliestere 
C6 = 100.000 pF poliestere 
*C7 = 1.000 mF elettr. 35 volt 
DS1 = diodo EM.513 o 1N.4007 
*RS1 = ponte raddriz. 100 V. 1 A. 

DZ1 = zener 7,5 volt 
*DL1 = diodo led 
TRI = NPN tipo BC.547 
TR2 = PNP tipo BC.327 
TR3 = NPN tipo BC.547 
IC1 = C/Mos tipo 74HC14 
IC2 = UA.78L05 
IC3 = UA.78L05 

*F1 = fusibile autoripr. 145 mA 
*T1 = trasformatore 3 watt (TN00.01) 
sec. 15 volt 0,2 Ampere 
*S1 = interruttore 
CONN.1 = connettore 25 poli 

Nota = I componenti contraddistinti dall’a¬ 
sterisco andranno montati sul circuito 
stampato siglato LX.1170/B. 
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Fig.4 Connessioni dell’SN.74HC14 viste da 
sopra e dei transistor NPN e PNP e dell’inte¬ 
grato stabilizzatore UA.78L05 viste da sotto. 









CI, che come visibile nello schema pratico di fig.7, 
deve essere collocato in posizione orizzontale. 

A questo punto potete inserire i tre transistor ed i 
due integrati stabilizzatori e poiché questi ultimi 
hanno le stesse dimensioni dei transistor, dovete 
controllare attentamente la loro sigla prima di sal¬ 
darli sullo stampato. 

Come potete vedere nello schema pratico di fig.7, 
la parte piatta dei due 78L05 (IC2 - IC3) va rivol¬ 
ta verso destra e così dicasi per il transistor BC.547 
siglato TRI .Gli altri due transistor, siglati TR2 (un 
BC.327) e TR3 (un BC.547), vanno inseriti rivol¬ 
gendo la parte piatta del loro corpo verso il basso 


e controllando con molta attenzione le loro sigle, in 
quanto uno è un PNP e l’altro un NPN. 

Per completare il montaggio non vi resta che inse¬ 
rire sulla parte alta dello stampato il connettore ma¬ 
schio d’uscita ed infilare nel suo zoccolo l’integra¬ 
to 74HC14, rivolgendo la sua tacca di riferimento 
verso destra. 

Lo stadio di alimentazione verrà montato sul cir¬ 
cuito stampato siglato LX.1170/B, e poiché questo 
è un monofaccia, in fig.8 potete osservare le sue 
dimensioni a grandezza naturale. 

Su questo stampato potete inserire come primo 
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Fig.6 In questa foto potete vedere come si 
presenta questo programmatore dopo aver 
montato tutti i suoi componenti. Si noti sul¬ 
la parte inferiore del circuito stampato lo 
zoccolo “textool”, che vi permetterà di in¬ 
serire tutti i microprocessori da program¬ 
mare senza sforzare i loro piedini. 



Fig.7 Schema pratico di montaggio dello 
stadio siglato LX.1170 e, a destra, del suo 
alimentatore siglato LX.1170/B. Facciamo 
presente che il CONN.1 può avere una for¬ 
ma diversa da come Tabbiamo disegnata. 
Se sul connettore fossero presenti due “tor¬ 
rette” (vedi foto), occorrerà toglierle. 




































































componente il trasformatore di alimentazione, i cui 
piedini risultano già predisposti per entrare solo nel 
loro giusto verso. 

Quindi proseguite e completate il montaggio anche 
di questo stampato inserendo il ponte raddrizza¬ 
tore, il condensatore elettrolitico C7 rispettando la 
polarità dei due terminali, la resistenza R9, che ser¬ 
ve ad alimentare il diodo led, ed il fusibile autori- 
pristinante siglato FI. 

MONTAGGIO NEL MOBILE 

L’interfaccia verrà fissata dentro un piccolo mobile 
plastico tipo consolle (vedi fig.11). 

Come prima operazione fissate sul mobile il suo 
pannello frontale utilizzando delle viti del diame¬ 
tro di 2 mm o delle piccole viti autofilettanti. 

Su tale pannello fissate con quattro viti lo stampa¬ 
to LX.1170, ma prima di eseguire questa opera¬ 
zione dovete stagnare sui due terminali di alimen¬ 
tazione uno spezzone di filo rosso per il positivo 
ed uno di filo nero per il negativo. 

Sul piano del mobile fissate lo stampato dell’ali¬ 


mentatore utilizzando i distanziatori plastici con ba¬ 
se autoadesiva che trovate nel kit. 

Sul piccolo pannello della consolle va invece fis¬ 
sato il portaled e l’interruttore di rete SI. 

A questo punto dovete effettuare i pochi collega- 
menti richiesti per portare la tensione di alimenta¬ 
zione all’interfaccia LX.1170, al diodo led ed all’in¬ 
terruttore di rete (vedi figg.7-8). 

COME COLLEGARLO al COMPUTER 

Dopo aver montato il programmatore siglato 
LX.1170 dovete collegarlo alla presa della porta 
parallela del computer, cioè a quella che ora uti¬ 
lizzate per la stampante. Questa porta si distingue 
da quella seriale perché è femmina. 

Per questo collegamento non potete usare il con¬ 
nettore che sfilerete dalla stampante, perché que¬ 
sto non può innestarsi nel connettore maschio 
presente sull’uscita del programmatore. 

Per collegare il programmatore al computer potete 
usare un qualsiasi cavo seriale provvisto ad una 

























































estremità di un connettore maschio che va inne¬ 
stato nel computer, e dall’altra di un connettore 

femmina che va innestato nel programmatore. 

IL COMPUTER da USARE 

Per programmare gli ST62 bisogna disporre di un 
qualsiasi personal computer IBM compatibile, non 
importa se europeo o se costruito ad Hong-Kong o 
a Taiwan. 

A tutti coloro che ci chiedono perché presentiamo 
programmi per soli IBM compatibili rispondiamo 
che la maggior parte dei programmi reperibili fun¬ 
zionano sotto DOS e poiché questo è il sistema o- 
perativo usato su tutti i computer IBM compatibi¬ 
li non è possibile adattare i programmi scritti per 
DOS per i computer tipo APPLE - AMIGA - AM- 
STRAD ecc. 

Questa scelta non è nostra, ma delle Case di 
software che avendo constatato che i computer 
IBM compatibili sono i più diffusi in Europa - A- 
merica - Asia, si sono orientate a realizzare solo 
programmi per DOS. 

In questo modo le Case di software vendono un 
numero maggiore di programmi, quindi riducono i 
costi di copyright ed in più hanno la certezza che 
questi programmi funzioneranno su qualsiasi mo¬ 
dello e marca di computer, perché usati sul siste¬ 
ma operativo più diffuso. 

Ritornando al computer IBM compatibile, non im¬ 
porta di quale marca o tipo e neanche se il modello 
è vecchio o nuovo, deve soltanto essere dotato di 



Fig.9 Foto dello stadio di alimentazione che 
una volta montato dovrete fissare sul co¬ 
perchio del mobile con tre distanziatori pla¬ 
stici autoadesivi (vedi fig.10). 


Fig.10 Lo stampato del programmatore si¬ 
glato LX.1170 andrà fissato sul pannello del 
mobile con quattro viti più dado. Sul pan¬ 
nello inclinato dello stesso mobile fisserete 
il portaled e l’interruttore di accensione. 


































Programmatore x ST6 i*p 


Fig.11 II mobile scelto per questo programmatore completo delle sue mascherine già fo¬ 
rate e serigrafate fornisce al progetto un aspetto molto professionale. Quello che più ap¬ 
prezzerete di questo progetto è la facilità con cui riuscirete, con il dischetto da noi forni¬ 
to, a programmare qualsiasi tipo di microprocessore ST62. 


una scheda grafica che rientri nel tipo CGA - 

EGA - VGA - SuperVGA. 


INSTALLAZIONE del PROGRAMMA 

Con il kit riceverete il dischetto floppy fornito dal¬ 
la SGS Thomson, indispensabile per poter pro¬ 
grammare tutti i microprocessori della serie ST62. 
In questo dischetto abbiamo inserito dei program¬ 
mi che vi permetteranno di semplificare tutte le o- 
perazioni necessarie per scrivere un programma, 
per modificarlo e poi assemblarlo ed ovviamen¬ 
te per trasferirlo aN’interno della memoria di un mi¬ 
croprocessore ST62. 

Il programma vi indicherà inoltre se avete com¬ 
messo degli errori, se avete inserito un ST62 bru¬ 
ciato, se la memoria del microprocessore è vergi¬ 
ne o già occupata da un altro programma. 


Per iniziare a prendere confidenza con i micropro¬ 
cessori ed imparare a trasferire su questi un pro¬ 
gramma presente neH’Hard-Disk, abbiamo ag¬ 
giunto nello stesso dischetto tre semplici pro¬ 
grammi, che una volta trasferiti all’interno di un 
ST62 vi permetteranno di verificare se avete ese¬ 
guito correttamente tutte le operazioni di trasferi¬ 
mento dati. 

Per copiare nell’Hard-Disk quanto è contenuto in 
questo dischetto dovete eseguire soltanto poche 
semplici istruzioni. 

Quando, dopo aver acceso il computer, sul moni¬ 
tor appare la scritta C:\>, inserite il dischetto nell’u¬ 
nità floppy poi digitate: 

C:\>A: poi Enter 

A:\>installa poi Enter 

Nota: Usate solo queste istruzioni e non altre, co¬ 
me ad esempio il COPY del DOS o le istruzioni dei 


































Fig.12 Per trasferire nell’Hard-Disk i pro¬ 
grammi contenuti nel dischetto dovete di¬ 
gitare A:\>INSTALLA poi premere Enter. 
Tutti i programmi verranno memorizzati nel¬ 
la directory C:\ST6. 



Fig.13 Poiché i programmi nel dischetto ri¬ 
sultano compattati, durante l’operazione di 
scompattazione apparirà sul monitor l’inte¬ 
ro elenco dei files. Il programma occupa 1 
Mega circa di memoria. 



Fig.14 Scompattati tutti i programmi con 
successo, il computer ve lo segnalerà fa¬ 
cendo apparire sul monitor questa scritta. 
Per uscire da questa finestra pigiate un ta¬ 
sto qualsiasi. 


programmi tipo PCSHELL - PCTOOLS - NORTON 

Commander, perché il programma non funzione¬ 
rebbe. 

Con le due semplici istruzioni trascritte sopra, crea¬ 
te automaticamente una directory chiamata ST6, 
nella quale vengono memorizzati tutti i files conte¬ 
nuti nel dischetto. 

Durante l’operazione di scompattazione appare sul 
monitor l’elenco dei files (vedi fig.13). 

Quando il programma è interamente memorizzato, 
appare un messaggio a conferma che l’installazio¬ 
ne è stata completata. 

Il programma scompattato occupa circa 1 Me¬ 
gabyte di memoria. 

Se non premete nessun tasto, dopo qualche mi¬ 
nuto compare la scritta: 

C:\ST6> 

Se volete uscire dalla directory ST6 sarà suffi¬ 
ciente digitare: 

C:\ST6>CD \ poi Enter 

e comparirà così sul monitor C:\>. 

Una volta installato il programma nell’Hard-Disk po¬ 
tete mettere da parte il dischetto floppy, perché 
non vi servirà più. 

COME si RICHIAMA il PROGRAMMA 

Tutte le volte che volete richiamare il programma 
ST6, quando sul monitor appare C:\> dovete digi¬ 
tare queste semplici istruzioni: 

C:\>CD ST6 poi Enter 
C:\ST6>ST6 poi Enter 

Se dovesse comparire una directory diversa da 
C:, ad esempio: 

C:\JVFAX> 

dovete digitare: 

C:\JVFAX>CD \ poi Enter 
C:\>CD ST6 poi Enter 

C:\ST6>ST6 poi Enter 

Sul monitor comparirà così il menu principale (ve¬ 
di fig.15). 

Nota: Le scritte colorate in azzurro appaiono di¬ 
rettamente sul monitor, quelle senza colore dovre¬ 
te digitarle dalla tastiera. 




































Fig.18 Premendo il tasto P = Programma do¬ 
po pochi secondi apparirà sul monitor del 
computer il software della SGS scritto in 
lingua inglese. Per continuare pigiate un 
qualsiasi tasto. 



Fig.19 Sullo schermo apparirà una lista con 
tutti i tipi di ST6 che potete programmare e 
che sono circa 20. Per selezionare la sigla 
del vostro microprocessore usate i tasti 
freccia su e giù. 



Fig.20 Poiché dovete programmare un 
ST62E10 portate il cursore su questa sigla 
poi pigiate Enter. Sullo schermo apparirà 
questa finestra con in basso l'indicazione 
dell’ST62E10. 







































Fig.21 Dalla finestra di fig.20 premete il ta¬ 
sto L = Load e apparirà questa finestra. Qui 
dovete scrivere il nome del programma che 
volete trasferire dall’Hard-Disk al micropro¬ 
cessore ST62E10. 



Fig.22 Dopo aver pigiato Enter apparirà la 
scritta “File checksum” per avvisarvi che il 
computer ha selezionato il programma, ma 
non l’ha ancora trasferito sul micro vergi¬ 
ne. Per continuare premete un tasto. 



Fig.23 Pigiando un qualsiasi tasto apparirà 
la finestra di fig.20. Per programmare 
TST62E10 che avete inserito nello zoccolo 
textool del programmatore pigiate il tasto P 
= Prg e di seguito il tasto N. 
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Fig.24 Quando compare questa scritta, non 
toccate più nessun tasto, perché il compu¬ 
ter dopo aver verificato che TST62E10 è ver¬ 
gine, provvede a programmarlo impiegan¬ 
do circa 9-15 secondi. 



Fig.25 Completata la programmazione, sul¬ 
lo schermo apparirà questa scritta. A que¬ 
sto punto pigiate un qualsiasi tasto e così 
ritornerete al menu di fig.20. Per uscire ba¬ 
sterà premere X. 



Fig.26 Quando sul monitor appare il menu 
di fig.20, se volete proteggere il micro dal¬ 
la lettura dovete premere il tasto K = locK 
poi Y. L’ST62E10 anche se “protetto” si può 
cancellare. 
















































































A questo punto molti penseranno di aver già risol¬ 
to tutti i loro problemi, ma poiché non è nostra a- 
bitudine illudere nessuno, vogliamo subito precisa¬ 
re che se non conoscete l’architettura di un mi¬ 
croprocessore e non avete ancora una seppure 
minima conoscenza generale di come scrivere un 
programma, saranno necessari dai 3 ai 6 mesi di 
pratica per poter diventare autosufficienti. 

Per questo motivo abbiamo inserito nel dischetto 
tre semplici programmi che oltre a servirvi per ef¬ 
fettuare le prime prove pratiche di trasferimento di 
dati verso le memorie del microprocessore, po¬ 
tranno esservi utili per capire come si imposta un 
programma per ST62. Vi spiegheremo infatti an¬ 
che come richiamare e visualizzare tutte le istru¬ 
zioni dei vari programmi. 

CARICARE un PROGRAMMA 

Per trasferire aH’interno della memoria vergine di 
un microprocessore ST62 uno dei tre programmi 
che noi abbiamo scritto, bisogna innanzitutto inse¬ 
rire il microprocessore nello zoccolo textool e bloc¬ 
carlo spostando verso il basso la levetta. 

Nel kit del programmatore troverete un ST62E10 
che ha una memoria EPROM utile di 2 Kbyte. 
Ovviamente potete caricare uno dei nostri pro¬ 
grammi anche su un ST62E25 da 4 Kbyte di me¬ 
moria EPROM, che però oltre ad essere più co¬ 
stoso, non può essere utilizzato sulla scheda spe¬ 
rimentale LX.1171, pubblicata su questa rivista, 
perché ha 28 piedini. 

Poiché LST62E10 ha soltanto 20 piedini, dovete 
collocarlo nello zoccolo come visibile in fig.27, cioè 
in basso e rivolgendo la tacca di riferimento ver¬ 
so l’alto. 

Eseguita questa operazione potete richiamare il 
programma (vedi paragrafo Come si richiama il 
Programma). 

Quando sul monitor del vostro computer appare il 
menu di fig.15, per proseguire dovete conoscere il 
nome del file da trasferire e per questo dovete sem¬ 
plicemente premere: 

F3 

Sullo schermo apparirà una nuova finestra con l’e¬ 
lenco dei programmi presenti in memoria (vedi fig. 
16). I programmi scritti da noi hanno questi nomi: 

CONTA. ASM 

LED.ASM 

LOTTO.ASM 

Nota: Oltre a questi tre files ne troverete un quar¬ 
to chiamato STANDARD.ASM, che a differenza 
degli altri, non contiene un programma da carica¬ 


re nel microprocessore. In questo file abbiamo vo¬ 
luto inserire tutte le istruzioni standard che occor¬ 
re richiamare in ogni programma e che vi risulte¬ 
ranno utilissime nel prossimo articolo, dedicato al¬ 
le istruzioni dei programmi per ST62. 

Di questi files ne dovete scegliere uno solo, per¬ 
ché all’interno di un microprocessore potete inse¬ 
rire un solo programma alla volta. 

Ammesso di aver scelto il primo, cioè LED.ASM, 
dovete ricordare il solo nome LED tralasciando l’e¬ 
stensione .ASM, che non vi serve durante la pro¬ 
grammazione del microprocessore. 

L’estensione .ASM è l’abbreviazione della parola 
Assembler. 

A questo punto potete uscire da questa finestra 
premendo il tasto Escape e vedrete riapparire la 
pagina del menu principale (vedi fig.15). 

Tenendo premuto il tasto ALT dovete premere il ta¬ 
sto T = ST6 ed apparirà una finestra con in alto la 
scritta Assembla - Programma (vedi fig.17). 

Premete ora il tasto P = Programma, e dopo al¬ 
cuni secondi comparirà l’intestazione del software 
di programmazione della SGS in lingua inglese (ve¬ 
di fig.18). 

Per continuare dovete pigiare un qualsiasi tasto e 
così comparirà la finestra di fig.19. 

Premendo i tasti frecce giù o su, potete visualiz¬ 
zare e selezionare tutti i tipi di microprocessori 
ST62 che questa interfaccia è in grado di pro¬ 
grammare. 

Poiché dovete programmare un ST62E10, andate 
con il cursore sulla riga in cui appare questa scrit¬ 
ta e pigiate Enter. 

Sul monitor comparirà la pagina di fig.20 ed in bas¬ 
so a destra vedrete la sigla del tipo di micropro¬ 
cessore selezionato, che nel nostro caso è: 

DEVICE: ST62E10. 

Pigiate il tasto L = Load e nella maschera che ap¬ 
pare scrivete il nome del file che volete memoriz¬ 
zare aH’interno dell’ST62E10. 

Poiché per questo esempio abbiamo scelto il file 
LED, scrivete questo nome nella riga (vedi fig.21) 
poi premete Enter. 

Dopo pochi secondi comparirà una seconda fine¬ 
stra rossa (vedi fig.22) con scritto File checksum 
= un numero esadecimale di controllo. 

Poiché questo numero non vi serve, pigiate un 
qualsiasi tasto. 




Fig.27 Tutti gli ST62 a 20 piedini 
andranno inseriti nello zoccolo 
textool in basso rivolgendo ver¬ 
so l’alto la tacca di riferimento. 
Anche gli ST62 a 28 piedini an¬ 
dranno inseriti nello zoccolo tex¬ 
tool rivolgendo verso l’alto la tac¬ 
ca di riferimento. 



Apparirà così la finestra bianca visibile in fig.20 e 
a questo punto dovete solo pigiare il tasto P = Prg 
e sul monitor vedrete la pagina visibile in fig.23. 

Ora pigiate il tasto N in modo che il computer inizi 
a controllare il microprocessore inserito nello zoc¬ 
colo textool. 

Nota: Non pigiate mai il tasto Y e se per sbaglio 

lo premete, annullate questo comando pigiando il 
tasto Escape, quindi premete ancora il tasto P e di 
seguito N. 

Dopo aver premuto N sul monitor apparirà questa 
scritta: 

Verifying thè target chip ... Please Wait 

Verifica chip da programmare ... attendi 

Se tutto risulta regolare, dopo pochi secondi ap¬ 
parirà sul monitor la finestra di fig.24 con la scrit¬ 
ta: 

Programming thè target chip ... Please wait! 

Programmazione in corso ... attendi! 

L’operazione di scrittura dei dati dal computer ver¬ 
so le memorie del microprocessore ST62 richie¬ 
de circa 9-15 secondi. 

A programmazione completata sul monitor appare 
questa scritta (vedi fig.25): 

The device is successfully programmed 

Microprocessore programmato con successo 

Poiché l’operazione di caricamento dati nell’ST6 


è completata, potete già estrarre l’ST62 dallo zoc¬ 
colo textool per inserirlo nel circuito siglato 
LX.1171 (vedi articolo su questa rivista a pag.56). 

Per uscire dal programma premete un tasto qual¬ 
siasi e di seguito il tasto X. Ritornerete così al me¬ 
nu principale di fig.15. 

GLI ERRORI che possono COMPARIRE 

Può succedere che per disattenzione premiate il ta¬ 
sto sbagliato o che il microprocessore che inserite 
nello zoccolo textool sia difettoso. 

In questi casi sarà il programma a segnalarvi con 
alcuni messaggi in inglese l’anomalia o l’errore 
commesso cosicché possiate correggerlo. 

Target Chip not presente or detective 

L’integrato non c’è o è difettoso 

Questo messaggio appare ogni volta che vi di¬ 
menticate di inserire il microprocessore nello zoc¬ 
colo textool oppure quando il microprocessore che 
avete inserito è bruciato. 

Non sempre però il microprocessore è fuori uso, 
perché questo identico messaggio appare anche 
quando: 

- avete inserito il microprocessore nello zoccolo 
textool rivolgendo la tacca di riferimento verso il 
basso anziché verso l’alto, come visibile in fig.27. 

- non avete innestato bene i connettori nel com¬ 
puter o nell’interfaccia LX.1170. 

- vi siete dimenticati di accendere l’interfaccia del 
programmatore. 














Device already programmed 
Continue Programming? Y/N 

L’integrato è già programmato 
vuoi continuare? Si/No 

Questo messaggio compare quando nello zoccolo 
textool avete inserito un microprocessore ST62 
che risulta già programmato. 

In questo caso dovete premere il tasto N per ritor¬ 
nare così alla finestra di fig.20. 

A questo punto potete togliere dallo zoccolo tex¬ 
tool il microprocessore per cancellarlo (vedi pa¬ 
ragrafo Per cancellare un ST62/E) e quindi ripro¬ 
grammarlo oppure inserire nello zoccolo un ST62 
vergine e ripetere tutte le operazioni per la pro- 
grammazione.Vi chiederete allora a cosa serve il 
comando Y, che conferma al programma di prose¬ 
guire nella programmazione. 

Se premete il tasto Y lasciando nello zoccolo tex¬ 
tool l’ST62 già programmato, non accadrà nulla, 
cioè il programma presente al suo interno non si 
cancellerà ed il nuovo non sarà mai memorizza¬ 
to nella sua memoria. 

Poiché nessuno ha mai chiarito quando è possibi¬ 
le usare il comando Y, cercheremo di spiegarvelo 
noi utilizzando degli esempi. 

Se durante la fase di programmazione, quando 
all’interno della memoria del microprocessore è già 
stato trasferito un 50% di dati, venisse improvvisa¬ 
mente a mancare la corrente di rete, voi vi trove¬ 
reste con un microprocessore programmato per 
metà che risulterebbe inutilizzabile. 

Una volta ritornata la corrente, il computer leg¬ 
gendo all’interno dell’ST62 anche solo una parte di 
programma, lo considererà già programmato, ma 
se in questo caso premerete il tasto Y, il computer 
trasferirà nella memoria dell’ST62 il restante 50% 
di programma mancante. 

Sempre durante la fase di programmazione, se si 


alzasse inavvertitamente la levetta dello zoccolo 
textool, i piedini dell’integrato non sarebbero più a 
contatto e quindi non entrerebbe più alcun dato nel 
microprocessore. 

Poiché qualche dato può già essere entrato 
nell’ST62, ripetendo tutte le operazioni di trasferi¬ 
mento il computer si accorgerà che nelle memorie 
è già presente un programma e subito lo segna¬ 
lerà. 

Anche in questo caso premendo il tasto Y, il com¬ 
puter completerà l’inserimento dei dati che in pre¬ 
cedenza non erano stati memorizzati. 

Program result: Device fail at address xxx 

Trovato un errore all’indirizzo xxx 

Dove xxx è un numero esadecimale. 

Questo messaggio appare ogniqualvolta il compu¬ 
ter non riesce a trasferire correttamente i dati nel¬ 
la memoria del microprocessore. 

Normalmente questo si verifica quando il micro- 
processore ST62 è già stato riprogrammato più di 
un centinaio di volte. 

Se questo messaggio compare spesso, è consi¬ 
gliabile sostituire il microprocessore. 

Per CARICARE un altro PROGRAMMA 

Se volete riutilizzare un microprocessore già pro¬ 
grammato per trasferire nella sua memoria un di¬ 
verso programma, dovete prima di tutto cancella¬ 
re i dati al suo interno, dopodiché potete ripetere 
tutte le operazione già descritte. 

Proseguendo nel nostro esempio, se dopo aver 
memorizzato il programma LED volete provare le 
funzioni del programma CONTA ed in seguito quel¬ 
le del programma LOTTO, solo dopo aver cancel¬ 
lato il microprocessore potrete trasferire dal com¬ 
puter i dati contenuti in uno di questi files. 



Fig.28 Per cancellare i microprocessori della serie ST62/E e tutti i tipi con EPROM, oc¬ 
corre esporre la loro finestra alla luce emessa da una lampada ultravioletta da 2.300-2.700 
Angstrom. Poiché queste lampade non sono facilmente reperibili, abbiamo provveduto ad 
ordinarne un certo numero ed appena ci perverranno (è prevista una consegna entro set¬ 
tembre) vi presenteremo un completo progetto provvisto di temporizzatore. 










Per PROTEGGERE un ST62 

Dopo aver constatato che il microprocessore pro¬ 
grammato funziona correttamente e siete certi che 
non volete più apportare modifiche al programma, 
ed inoltre non avete più alcuna necessità di rileg¬ 
gere i dati memorizzati al suo interno, vi conviene 
proteggerlo. 

Un microprocessore protetto tipo ST62/E si può 
cancellare per renderlo idoneo a ricevere altri pro¬ 
grammi. 

Per proteggere un microprocessore, sia del tipo 
ST62/T che del tipo ST62/E, lo si deve lasciare in¬ 
serito nello zoccolo textool e procedere come ora 
vi spiegheremo. 

Quando sul monitor appare il menu principale (ve¬ 
di fig.15), tornate nel menu di programmazione pre¬ 
mendo Alt+T e di seguito P e apparirà la fig.19. 
Selezionata la sigla del microprocessore che ave¬ 
te inserito nello zoccolo textool, quando appare il 
menu di fig.20 premete il tasto K = Lock e così ap¬ 
parirà sul monitor la finestra di fig.26. 

Per proteggerlo sarà sufficiente premere il tasto 
Y, se non lo volete proteggere premete il tasto N. 

Per CANCELLARE un ST62/E 

Tutti i microprocessori della serie ST62/E, cioè 
quelli provvisti di una piccola finestra (vedi fig.1), 
una volta programmati si possono cancellare e 
poi nuovamente riprogrammare per utilizzarli con 
un diverso programma. 

Per cancellare questi microprocessori occorre una 
lampada ultravioletta che lavori su una lunghez¬ 
za d’onda compresa fra i 2.300 e i 2.700 Angstrom. 
Sotto questa lampada va collocato il microproces¬ 
sore tenendo la sua finestra ad una distanza di cir¬ 
ca 2 centimetri. 

A questa distanza per cancellare un microproces¬ 
sore occorrono dai 15 ai 20 minuti, sempre che la 
finestra risulti pulita. 

Se sopra tale finestra c’è della sporcizia, ad e- 
sempio rimangono dei residui di collante dopo a- 
ver rimosso un’etichetta autoadesiva, dovrete pri¬ 
ma pulirla con un batuffolo di cotone imbevuto di 
alcool o di acetone. 

Poiché la lunghezza del bulbo di una lampada ul¬ 
travioletta è di circa 30 cm, potete cancellare con¬ 
temporaneamente più ST62/E disponendoli uno di 
fianco all’altro (vedi fig.28). 

NOTE per la LAMPADA UV 

Se vi dimenticate il microprocessore sotto la lam¬ 
pada a raggi ultravioletti per una tempo superio¬ 


re ai 50 minuti non sono garantite più di 70 - 80 

cancellazioni. 

Se volete usare un solo microprocessore per ef¬ 
fettuare tantissime prove di memorizzazione e 
cancellazione, potete collegare la lampada ad u- 
no dei tanti temporizzatori o timer per lampade da 
220 volt pubblicati sulla nostra rivista (ad esempio 
il Kit LX.1068 pubblicato sulla rivista N.153), che 
potrete regolare per una accensione massima di 
10 minuti circa. 

A lampada accesa non fissate ASSOLUTAMEN¬ 
TE la luce viola che emette, perché nuoce grave¬ 
mente agli occhi. 

Per evitare questo inconveniente si potrà mettere 
sopra la lampada un panno o una scatola di car¬ 
tone. 

CONCLUSIONE 

Su questo stesso numero troverete un semplice 
progetto che oltre a permettervi di controllare se il 
microprocessore programmato con uno dei tre pro¬ 
grammi da noi inseriti nel dischetto, cioè LED - 
CONTA - LOTTO, funziona correttamente, vi con¬ 
sentirà di fare un po’ di pratica sulla cancellazio¬ 
ne di un ST62/E e sulla riprogrammazione. 

In questo articolo vi insegneremo anche ad appor¬ 
tare delle semplici varianti sul programma, men¬ 
tre nei prossimi articoli vi spiegheremo tutto il set 
di istruzioni per i microprocessori ST62, perché 
solo conoscendo il significato di queste istruzioni 
potrete un domani realizzare programmi persona- 
lizzati per far svolgere agli ST62 tutte le funzioni a 
voi necessarie. 


COSTO DI REALIZZAZIONE 

Costo di realizzazione dello stadio LX.1170 (vedi 
figg.6-7) completo di circuito stampato, zoccolo 
Textool, connettore d’uscita, transistor, integrati 
con INSERITO un microprocessore ST62/E10, un 
dischetto floppy contenenti i programmi richiesti, ed 
il CAVO seriale completo di connettori, ESCLUSI il 


mobile e lo stadio di alimentazione.€ 49,10 

Costo di realizzazione dello stadio di alimentazio¬ 
ne LX.1170/B (vedi fig.8) completo di cordone di a- 
limentazione.€ 11,60 

Il mobile MO.1170 completo delle due mascherine 
forate e serigrafate.€ 16,01 

Costo del solo stampato LX.1170.€ 5,42 

Costi del solo stampato LX.1170/B.€ 1,55 







Vogliamo subito precisare che questo circuito ser¬ 
ve per testare i programmi che avete imparato a 
trasferire nel microprocessore ST62E10 fornito nel 
kit del programmatore. 

Lo stesso circuito può essere utilizzato anche per 
i programmi che vorrete scrivere, a patto che con¬ 
figuriate le porte come le abbiamo configurate noi, 
diversamente non potrete sfruttarlo. 

In questo circuito di prova, che potete vedere in 
fig.1, vi sono due integrati, ma quello che abbiamo 
siglato IC1 è in pratica il microprocessore 
ST62E10 che dovete prima programmare, mentre 
l’integrato IC2, che trovate inserito nel kit, è un 
74LS244 utilizzato come buffer di corrente. 

Infatti dovete tenere presente che sulle uscite 
dell’ST62E10 non è possibile applicare dei carichi 
che assorbano più di 5 mA, e poiché questo cir¬ 
cuito viene utilizzato per accendere dei diodi led 
e dei display che assorbono una corrente mag¬ 
giore, abbiamo dovuto adoperare l’integrato 


Nel CONN.1 dovete inserire la scheda con i dio¬ 
di Led, se avete memorizzato nell’ST62E10 il 
programma LED o la scheda con i due Display 
se avete memorizzato nell’ST62E10 il program¬ 
ma CONTA o LOTTO. 

Per alimentare questa scheda occorre una ten¬ 
sione stabilizzata di 5 volt 200 milliAmpere cir¬ 
ca. 

REALIZZAZIONE PRATICA 

Sul circuito stampato siglato LX.1171 dovete 
montare tutti i componenti disponendoli come vi¬ 
sibile in fig.12. 

Lo schema è così semplice che non ha certo bi¬ 
sogno di particolari consigli, comunque una vol¬ 
ta stagnati tutti i terminali degli zoccoli e del con¬ 
nettore è consigliabile controllare con una lente 
d’ingrandimento che non vi sia una goccia di sta¬ 
gno tra due piedini che provochi un corto. 
Come visibile nel disegno dello schema pratico 


CIRCUITO TEST per 


Dopo aver imparato come memorizzare un programma all’interno di un 
microprocessore ST62E10, e aver constatato di persona che non è poi 
così difficile come viene invece descritto in altre parti, sarete assaliti 
dalla curiosità di “testarlo” e per questo vi occorre soltanto il semplice 
circuito che ora vi presentiamo. 


74LS244, che è in grado di sopportare carichi fino 
ad un massimo di 20 mA. 

Sempre guardando lo schema elettrico, sui piedini 
3-4 dell’ST62E10 trovate collegato un quarzo da 8 
MHz, che serve al microprocessore per generare 
la frequenza di clock necessaria per il suo funzio¬ 
namento. 

La frequenza di questo quarzo non è critica, quin¬ 
di potrete utilizzare anche quarzi di frequenza in¬ 
feriore, ad esempio 7-6-4 MHz, tenendo co¬ 
munque presente che più si scende di frequenza, 
più lenta risulta la velocità di esecuzione del pro¬ 
gramma. 

Non utilizzate quarzi con una frequenza maggiore 
di 8 MHz, perché il microprocessore non riuscirà a 
generare la necessaria frequenza di clock. 

Dei tre pulsanti presenti nel circuito, quelli siglati 
PI - P2 svolgono le funzioni rese disponibili dal pro¬ 
gramma, mentre P3 serve sempre e solo come co¬ 
mando di reset. 


conviene collocare il quarzo in posizione orizzon¬ 
tale, saldando il suo corpo sul circuito stampato 
con una goccia di stagno. 

Nello zoccolo IC2 (quello posto in alto verso il 
CONN.1) inserite l’integrato 74LS244 rivolgendo la 
tacca di riferimento verso il condensatore C2. 
Nello zoccolo IC1 inserite dopo averlo program¬ 
mato il microprocessore ST62E10, rivolgendo la 
tacca di riferimento verso il condensatore CI. 
Completato il montaggio di questo stampato pote¬ 
te prendere lo stampato siglato LX.1171/B e su 
questo saldare il connettore maschio, tutte le re¬ 
sistenze dalla R3 alla RIO ed i diodi led, come vi¬ 
sibile in fig. 14. 

Quando inserite i diodi led nel circuito stampato do¬ 
vete rivolgere il terminale più corto (terminale K) 
verso le resistenze. 

L’ultimo stampato, quello siglato LX.1171/D, prov¬ 
visto di due display vi servirà per testare i pro¬ 
grammi CONTA e LOTTO. 




microprocessore ST62E10 


Come visibile in fig.15 su questo stampato fissate 
le resistenze da RI ad R8, che sono da 220 ohm, 
e le due resistenze R9 - RIO che sono invece da 
4.700 ohm, poi il connettore maschio, i due tran¬ 
sistor TRI - TR2 rivolgendo la parte piatta del loro 
corpo verso destra e per ultimi montate i due di¬ 
splay, rivolgendo il lato con i punti decimali verso 
il basso. 

IMPORTANTE 

Se nel microprocessore ST62E10 avete memoriz¬ 
zato i dati del programma LED, dovrete inserire 
nel CONN.1 della scheda LX.1171 la scheda con 
gli 8 diodi led, se avete memorizzato i dati del pro¬ 
gramma CONTA o del programma LOTTO, do¬ 
vrete inserire la scheda con i 2 display. 

Se per errore scambiate le schede, non causere¬ 
te nessun danno né all’integrato IC2 né al micro- 
processore IC1, quindi basterà inserire la scheda 
giusta per vedere il circuito funzionare. 

Se il circuito non funziona, potreste esservi sba¬ 
gliati nel memorizzare il programma nelle memo¬ 
rie del microprocessore. 

In questo caso dovrete esporlo sotto una luce ul¬ 
travioletta per cancellare i dati dalla sua memoria, 
quindi dovrete riprogrammarlo. 


Questa stessa operazione va effettuata se dopo a- 
ver trasferito il programma LED volete sostituirlo 
con il programma CONTA o con il programma LOT¬ 
TO. 


COLLAUDO MICROPROCESSORE 
nel CIRCUITO TEST 

Dopo aver realizzato il circuito test siglato LX.1171 
potete collaudare il microprocessore che avete im¬ 
parato a programmare con uno dei tre semplici pro¬ 
grammi LED - CONTA - LOTTO, come vi abbiamo 
spiegato nell’articolo precedente. 

Per prima cosa dovete inserire nello zoccolo a 20 
piedini del circuito test LX.1171 il microprocesso¬ 
re appena programmato, rivolgendo la sua tacca di 
riferimento verso il condensatore CI (vedi fig.12). 
Dopo questa operazione, se avete programmato il 
microprocessore con il programma LED dovete in¬ 
nestare nel connettore femmina del circuito test 
LX.1171 il circuito applicativo a diodi led siglato 
LX.1171/B. 

Se invece avete programmato il microprocessore 
con uno qualsiasi dei due programmi CONTA o 
LOTTO, dovete innestare nel connettore femmina 












ELENCO COMPONENTI LX.1171 (test St6) 

RI = 10.000 ohm 1/4 watt 
R2 = 10.000 ohm 1/4 watt 
*R3-R10 = 100 ohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 22 pF a disco 
C4 = 22 pF a disco 
C5 = 1 mF elettr. 63 volt 
DS1 = diodo EM.513 o 1N.4007 
*DL1-DL8 = diodi led 
XTAL = quarzo 8 MHz 
IC1 = vedi nota 
IC2 = TTL tipo 74LS244 
P1-P3 = pulsanti 
CONN.1 = connettore 12 poli 

Nota = I componenti contraddistinti dall’a¬ 
sterisco andranno montati sul circuito 
stampato siglato LX.1171/B. L’integrato si¬ 
glato IC1 è il microprocessore incluso nel 
Kit del porgrammatore LX.1170, che po¬ 
trete inserire nel circuito dopo averlo pro¬ 
grammato. 


Fig.1 Schema elettrico del circuito che dovrete realizzare per poter verificare se il pro¬ 
gramma LED (vedi pagg.37-38) è stato correttamente memorizzato aN’interno del micro 
ST62E10. Per alimentare questo circuito occorre una tensione esterna stabilizzata di 5 volt. 


del circuito test il circuito applicativo con i due di¬ 
splay siglato LX.1171/D. 

A questo punto potete passare al collaudo vero e 
proprio del programma caricato nelle memorie del 
microprocessore. 

COLLAUDO PROGRAMMA LED 

Dopo aver programmato il microprocessore con il 
programma Led ed averlo inserito nel circuito stam¬ 
pato siglato LX.1171, dovete innestare il connetto¬ 
re maschio del circuito a diodi led nel connettore 
femmina presente sul circuito test, poi dovete ali¬ 
mentare quest’ultimo con una tensione di 5 volt 
stabilizzati. 


Il programma LED vi dà la possibilità di far lam¬ 
peggiare gli 8 diodi led presenti nel circuito con 5 
diverse modalità, che potete selezionare pigiando 
ripetutamente il pulsante PI. 

1 ° Lampeggio 

I led si accendono in sequenza uno alla volta da 
sinistra verso destra. Il ciclo continua all’infinito. 

2° Lampeggio 

I led si accendono due alla volta dall’esterno ver¬ 
so l’Interno (prima DL1 e DL8, poi DL2 e DL7 ecc.), 
fino ai due led centrali (DL4 e DL5), poi i led si ac¬ 
cendono sempre due alla volta, ma in senso in¬ 
verso, cioè dall’interno verso l’esterno. Il ciclo con¬ 
tinua all’infinito. 











































3° Lampeggio 

Si accende tutta la fila di led, iniziando dal primo a 
sinistra e proseguendo verso destra. Quando so¬ 
no tutti accesi si spengono tutti insieme. Il ciclo ri¬ 
prende all’infinito. 


4° Lampeggio 

Lampeggiano uno alla volta prima i led pari poi i 
dispari, poi si spengono e si accendono tutti in¬ 
sieme. Il ciclo continua all’infinito. 


5° Lampeggio 

I led si accendono prima tutti insieme, poi si spen¬ 
gono tutti insieme. Il ciclo si ripete all’infinito. 

Non appena il circuito viene alimentato, il micro- 
processore esegue il 1 ° motivo. Premendo ripetu¬ 
tamente il pulsante PI vengono eseguiti uno di se¬ 
guito all’altro il 2° - 3° - 4° - 5° motivo. Se mentre 
è in corso il 5° premete nuovamente PI, il micro- 
processore eseguirà di nuovo il 1 ° lampeggio. 
L’intervallo fra un’accensione dei diodi led e l’altra 
è di circa 1/2 secondo, ma è possibile diminuire 
questo tempo premendo ripetutamente P2. 

La massima velocità di lampeggio consentita dal 
programma viene raggiunta dopo aver premuto 
questo pulsante per 8 volte. 

Premendolo ancora una volta, il lampeggio ripren¬ 
derà con la stessa velocità iniziale. 

Premendo in qualunque momento il pulsante P3 
(RESET), il microprocessore tornerà ad eseguire il 


programma da capo, cioè ripartirà dal primo lam¬ 
peggio come se aveste alimentato solo in quel mo¬ 
mento il circuito. 

Se volete passare al collaudo di uno degli altri due 
programmi CONTA - LOTTO, dovete togliere l’ali¬ 
mentazione al circuito ed estrarre il circuito a led 
LX.1171/B. Ovviamente dovete pure estrarre il mi¬ 
croprocessore, e dopo averlo cancellato, dovete 
riprogrammarlo con uno degli altri due program¬ 
mi. 

COLLAUDO PROGRAMMA CONTA 

Dopo aver programmato il microprocessore con il 
programma Conta ed averlo inserito nel circuito 
stampato siglato LX.1171, dovete innestare il con¬ 
nettore maschio del circuito a display nel connet¬ 
tore femmina presente sul circuito test, poi dove¬ 
te alimentare quest’ultimo con una tensione di 5 
volt stabilizzati. 

Dopo aver alimentato il circuito vedrete comparire 
sui display il numero 00, che aumenterà di una u- 
nità ogni 1/2 secondo. 

Pertanto ogni 5 decimi di secondo leggerete 01 - 
02 - 03 - ecc. fino a 99, dopodiché il conteggio ri¬ 
partirà sempre in avanti da 00. 

Per ottenere un conteggio all’indietro, potete pre¬ 
mere in qualunque istante il pulsante P2. 
Supponendo di premere P2 quando sui display 
compare ad esempio il numero 74, vedrete appa¬ 
rire, sempre ad intervalli di 1/2 secondo, i numeri 



ELENCO COMPONENTI LX.1171/D 

R1-R8 = 220 ohm 1/4 watt 
R9 = 4.700 ohm 1/4 watt 
RIO = 4.700 ohm 1/4 watt 
TRI = PNP tipo BC327 
TR2 = PNP tipo BC327 
DISPLAY1-2 = display Anodo comune 
tipo HP.5082 o 7731 


Fig.2 Se all’interno del micro ST62E10 avete memorizzato il programma CONTA o LOT¬ 
TO, per poterlo controllare dovrete realizzare questo circuito elettrico. La scheda dei dio¬ 
di led o dei display andrà inserita nel connettore dell’LX.1171 (vedi figg.19-20). 







































73-72-71 - ecc., fino a 00, dopodiché il conteg¬ 
gio riprenderà da 99 per tornare a 00 e così all’in¬ 
finito. 

Premendo in qualunque momento il tasto PI il con¬ 
teggio proseguirà di nuovo in avanti e così pure 
premendo in qualsiasi momento il pulsante P2 il 
conteggio riprenderà aH’indietro. 

Infine potrete riprendere l’esecuzione del program¬ 
ma da capo premendo il pulsante P3 (RESET), per¬ 
ché in tal modo sarà come se aveste appena ali¬ 
mentato il circuito. 

In questo caso il conteggio ripartirà da 00 e verrà 
effettuato in avanti. 

COLLAUDO PROGRAMMA LOTTO 

Dopo aver programmato il microprocessore con il 
programma Lotto ed averlo inserito nel circuito 
stampato siglato LX.1171, dovete innestare il con¬ 
nettore maschio del circuito a display nel connet¬ 
tore femmina presente sul circuito test, poi dove¬ 
te alimentare quest’ultimo con una tensione di 5 
volt stabilizzati. 

Dopo aver alimentato il circuito vedrete comparire 
sui display due lineette (--) ed ogni volta che pre¬ 
merete il pulsante PI comparirà un numero sem¬ 
pre diverso compreso fra 01 e 90, cioè i numeri del¬ 
la tombola o del lotto. 

Ogni volta che premete PI il numero non sarà mai 
uguale ai precedenti, quindi potrete simulare una 
reale estrazione di numeri. 

Una volta estratti tutti i 90 numeri, vedrete com¬ 
parire sui display le due lineette (--), quindi sapre¬ 
te che sono stati estratti tutti i 90 numeri disponi¬ 
bili. 

Quando compaiono le due lineette (--), per inizia¬ 
re una nuova estrazione basterà premere PI , e co¬ 
sì sempre in maniera casuale ricompariranno i nu¬ 
meri compresi fra 00 e 90. 

Se invece volete iniziare una nuova estrazione in¬ 
terrompendo quella in corso, sarà sufficiente re¬ 
secare il microprocessore premendo il pulsante P3 
(RESET). In tal modo il programma verrà eseguito 
da capo, esattamente come se aveste appena ali¬ 
mentato il microprocessore, anche se i numeri non 
sono stati tutti estratti. 

In questo programma il pulsante P2 non viene uti¬ 
lizzato. 

PER VEDERE il LISTATO 
di un PROGRAMMA 

Le informazioni seguenti vi saranno utili quando 
vorrete entrare nel listato di un programma per mo¬ 
dificarlo. 

Per visualizzare un qualunque listato di uno dei pro- 



Fig.3 Per poter vedere il listato dei pro¬ 
grammi, quando sullo schermo appare il 
menu principale, pigiate F3 quindi sceglie¬ 
te quello che vi interessa, cioè Conta, Led 
o Lotto e premete Enter. 



C:vSTb>L».nSH 


Fig.4 Se sceglierete il programma Led, sul¬ 
lo schermo del computer appariranno tutte 
le righe di tale programma. Per uscire da 
questo listato dovete premere Alt ed F3 e 
apparirà il menu principale. 



Fig.5 I più esperti potranno apportare per¬ 
sonali modifiche a questi programmi pi¬ 
giando il tasto F2 per memorizzarle. Pi¬ 
giando Alt+F3 potrete non confermare le 
modifiche apportate. 












































gramma per ST62, anche senza bisogno di modi¬ 
ficarlo, dovete innanzitutto caricare il programma. 
Quando sul monitor del computer compare: 

C:\> 

digitate: 

C:\>CD ST6 poi Enter 
C:\ST6>ST6 poi Enter 

Così entrerete nel menu principale di fig.3. 

Premete il tasto F3 per visualizzare l’elenco dei fi- 
les contenenti i programmi per ST62. 

Premete Enter e dopo aver portato il cursore sul 
nome del file desiderato, premete ancora Enter. In 
questo modo comparirà il listato del programma 
contenuto in quel file. 

Per muovervi all’interno del listato e vedere così 
tutte le istruzioni usate i tasti freccia su/giù oppu¬ 
re i due tasti pagina su/giù. 

Per uscire dal listato di un file, dovete tenere pre¬ 
muto Alt e premere F3. Ritornerete così al menu 
principale (vedi fig.3). 

Nota: Se mentre visualizzate il listato premete per 
errore i tasti scrivendo nel file dei caratteri indesi¬ 
derati, senza curarvi di andarli a cancellare, pote¬ 
te uscire dal file senza salvare le modifiche. 

Per compiere questa operazione è sufficiente te¬ 
nere premuto il tasto Alt e premere F3, e quando 
appare la finestra di conferma di fig.7 dovete pre¬ 
mere il tasto N. 

Ricordate che se dopo aver modificato il file senza 
volerlo, premete inavvertitamente F2, le modifiche 
verranno salvate, quindi premendo Alt+F3 la fine¬ 
stra di conferma modifiche (vedi fig.7) non appa¬ 
rirà. 

In questo caso l’unico modo per correggere le mo¬ 
difiche è entrare di nuovo nel file, cercare la riga 
del listato dove avete apportato le modifiche e cor¬ 
reggerla. 

Nel caso non riusciate a correggere l’errore nean¬ 
che in questo modo, non vi rimane altro che in¬ 
stallare di nuovo il programma, perché in tal caso 
caricherete nell’Hard-Disk i programmi originali 
contenuti nei files LED - CONTA - LOTTO. 

Per MODIFICARE un PROGRAMMA 

Chi sa già programmare potrebbe trovare questo 
paragrafo poco interessante, ma poiché dobbiamo 
pensare anche a tutti i principianti, riteniamo ne¬ 
cessario spiegare anche quello che per molti po¬ 
trebbe essere ovvio. 



Fig.6 Una volta salvate le modifiche con F2 
(vedi fig.5) dovrete riassemblare tutto il pro¬ 
gramma. Premete Alt+T e quando apparirà 
questa finestra pigiate il tasto A. L’assem¬ 
blaggio dura solo pochi secondi. 
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Fig.7 Se non volete memorizzare le modifi¬ 
che effettuate NON dovrete pigiare il tasto 
F2, ma solo Alt+F3 e così apparirà questa 
finestra. A questo punto dovrete semplice- 
mente pigiare N. 



Fig.8 Se prima di programmare un ST62E10, 
seguendo quanto descritto da pag.26, pi¬ 
giate il tasto B, il computer vi dirà se il mi¬ 
croprocessore inserito nello zoccolo tex- 
tool è vergine. 

























































Fig.9 Se tentate di programmare un 
ST62E10 già programmato il computer vi 
mostrerà questa scritta. Se volete inserire 
un diverso programma, dovrete premere N 
e cancellare il micro. 



Fig.10 Se nel programmare un micropro¬ 
cessore vi dimenticate di scrivere il nome 
del file del programma, Conta - Led - Lotto, 
il computer lo segnalerà con questo mes¬ 
saggio. 



Fig.11 Se il microprocessore è stato inseri¬ 
to nello zoccolo textool in modo errato o se 
il programmatore non è alimentato, sullo 
schermo del computer apparirà questo 
messaggio. 


Sapere come entrare in un file e come procedere 
per modificare qualcuna delle istruzioni dei pro¬ 
grammi che vi abbiamo fornito, costituisce un pri¬ 
mo importante passo per tutti coloro che non han¬ 
no mai visto come sono scritte le diverse righe di 
un programma e che in un secondo tempo vorran¬ 
no provare a realizzare dei semplici e personali pro¬ 
grammi. 

Per spiegarvi queste prime cose prenderemo spun¬ 
to dal programma più semplice che vi abbiamo pro¬ 
posto, quello cioè chiamato LED, e su questo vi in¬ 
segneremo come si deve procedere per cambiare 
le modalità di lampeggio degli 8 diodi led, cioè per 
fare in modo che i diodi led possano lampeggiare 
in modo diverso da quello da noi proposto. 

Quando, dopo aver caricato il programma, compa¬ 
re il menu principale di fig.3, premete il tasto F3 (ta¬ 
sto per l’apertura dei files). 

Apparirà la finestra con l’elenco dei file dei pro¬ 
grammi, cioè: 

CONTA. ASM 
LED.ASM 
LOTTO.ASM 
STANDARD. ASM 

Nota: Il file STANDARD.ASM non contiene un pro¬ 
gramma vero e proprio, ma delle utili indicazioni 
per capire il significato, l’uso e l’importanza delle 
varie istruzioni di ogni programma per ST62. Co¬ 
me vi spiegheremo nel prossimo paragrafo, potre¬ 
te entrare in questo file e leggere tutti gli utili com¬ 
menti che abbiamo inserito. 

A questo punto premete Enter, portate il cursore 
sulla riga LED.ASM e premete ancora Enter. 

Sul monitor comparirà tutto il listato del program¬ 
ma contenuto nel file LED.ASM (vedi fig.4). 

In basso a sinistra sono presenti due numeri se¬ 
parati dai due punti (:). Il primo numero vi per¬ 
mette di identificare la riga del programma, il se¬ 
condo la colonna del file. 

Con i tasti freccia giù o pagina giù portate il cur¬ 
sore in prossimità della riga 255, cioè scendete con 
il cursore fino a quando in basso a sinistra non leg¬ 
gete 255:1. 

Dalla riga 255 in poi (vedi fig. 5) compaiono delle 
istruzioni del tipo: 


lampi .byte 1111111 Ob ; Prima istruzione 
.byte 11111101 b ; Seconda istruzione 


























.byte 11111011b ; Terza istruzione 
.byte llllOlllb ; Quarta istruzione 
.byte lllOllllb ; Quinta istruzione 
.byte IlOlllllb ; Sesta istruzione 
.byte lOllllllb ; Settima istruzione 
.byte Olllllllb ; Ottava istruzione 

dove lampi sta ad indicare che le istruzioni suc¬ 
cessive sono relative alla prima modalità di lam¬ 
peggio dei diodi led. 

Nota: Le scritte dopo il punto e virgola (;) non so¬ 
no istruzioni, ma commenti, che abbiamo inseri¬ 
to appositamente nel listato per rendere più com¬ 
prensibili le spiegazioni che ora vi daremo. Per que¬ 
sto motivo vi consigliamo di non cambiarle. 

Per capire in che modo è possibile cambiare que¬ 
ste istruzioni per variare la modalità di accensione 
dei vari diodi led, cercheremo di spiegarvi in modo 
molto semplice come funzionano queste istruzioni. 



Fig.12 Schema pratico di montaggio della 
scheda sperimentale LX.1171. L’integrato 
IC1 è il microprocessore ST62E10 che vi ab¬ 
biamo fatto programmare con il progetto 
pubblicato a pag.26.1 pulsanti PI - P2 vi ser¬ 
viranno per modificare le funzioni o la ve¬ 
locità (leggere articolo), mentre il pulsante 
P3 serve per resettare il circuito. 


Le cifre siglate 1 e 0 che trovate dopo l'istruzione 
.byte compongono un numero binario, riconosci¬ 
bile per la presenza della lettera b = binario. 
Come noterete, queste cifre binarie sono 8 e ad 
ognuna di esse corrisponde un diverso diodo led 
del circuito test LX.1171/B (vedi fig.1). 

Ad esempio, alla prima cifra da destra corrispon¬ 
de DL1, alla seconda corrisponde DL2, e così via 
fino all’ottava cifra da destra, alla quale corrispon¬ 
de DL8. 

Ogni volta che il microprocessore esegue un’istru¬ 
zione come: 

.byte 11111011b ; Terza istruzione 

i diodi led corrispondenti alle cifre binarie uguali a 
0 vengono accesi, mentre i diodi led corrispondenti 
alle cifre binarie uguali ad 1 rimangono spenti. 
Quindi quando il microprocessore esegue questa 
istruzione, viene acceso il solo diodo DL3, mentre 
tutti gli altri rimangono spenti. 



Fig.13 Foto del circuito LX.1171 come si 
presenta a montaggio ultimato. Si noti nel¬ 
lo zoccolo IC1 il microprocessore ST62E10 
provvisto della finestra di cancellazione ed 
in alto il connettore per poter inserire la 
scheda con i diodi led (vedi fig.14) o con i 
display (vedi fig.15) Il circuito va alimenta¬ 
to con una tensione di 5 volt. 
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Fig.14 Schema pratico di montaggio della 
scheda a diodi led da usare se avete me¬ 
morizzato neirST62E10 il programma LED. 


Fig.15 Schema pratico della scheda display 
da usare se nell’ST62E10 avete memoriz¬ 
zato il programma CONTA oppure LOTTO. 



Fig.16 Foto della scheda LX.1171/B dei dio¬ 
di Led a montaggio ultimato. 
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Fig.17 Foto della scheda LX.1171/D dei di¬ 
splay a montaggio ultimato. 
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Fig.18 Connessioni dei display viste da dietro, del transistor BC.327 viste da sotto e dell’in¬ 
tegrato 74LS244 viste da sopra. Il terminale più lungo presente nei diodi led è l’Anodo. 
















































Se nelle diverse righe di istruzione si scrivono dif¬ 
ferenti numeri binari, il microprocessore accenderà 
ogni volta dei diodi led diversi, ed in questo modo 
potrete creare differenti giochi di luce. 

Se ad esempio considerate le istruzioni del lam¬ 
peggio chiamato lampi, vedete che quando viene 
eseguita la prima istruzione si accende solo il dio¬ 
do DL1, perché solo la cifra più a destra è uno 0, 
poi quando viene eseguita la seconda istruzione 
si accende solo DL2 e così via. In questo modo si 
è realizzata una semplice accensione in sequenza 
di un solo diodo alla volta. 

Cambiando le cifre 1 e 0 che compongono i vari 
numeri binari potete realizzare con un po’ di fanta¬ 
sia tutti i giochi di lampeggio che vorrete. 

Per cambiare le cifre che compongono i numeri bi¬ 
nari è sufficiente che vi portiate col cursore sulla ci¬ 
fra che volete modificare, dopodiché potete scrive¬ 
re 1 o O.Per cancellare la cifra binaria che volete 



Fig.l 9 Se avete programmato il micropro¬ 
cessore con il programma LED dovrete in¬ 
serire nel connettore dell’LX.1171 il con¬ 
nettore maschio della basetta di fig.l4. 


sostituire portate il cursore su quella cifra e pre¬ 
mete il tasto Cane. 

Ricordate che ogni numero binario deve essere 
composto da non più di 8 cifre, altrimenti il pro¬ 
gramma non funzionerà. 

Se scrivete un numero di cifre inferiori ad 8 il pro¬ 
gramma funzionerà ugualmente, ma i diodi corri¬ 
spondenti alle cifre non utilizzate rimarranno sem¬ 
pre accesi. Ad esempio, scrivendo IlOlOb, cioè 
tralasciando le tre cifre corrispondenti ai diodi DL6 

- DL7 - DL8, questi diodi rimarranno sempre ac¬ 
cesi. 

Se volete potete cambiare le cifre binarie di tutti i 
5 giochi proposti, quindi potete modificare anche 
le istruzioni scritte dopo le etichette Iamp2 - Iamp3 

- Iamp4 - Iamp5. Troverete queste scritte scorren¬ 
do con il cursore il listato del programma. 

I giochi di luce supportati da questo programma so¬ 
no solo 5, quindi non aggiungete altre etichette del 


4 ? 1 , 



Fig.20 Se avete programmato il micropro¬ 
cessore con il programma CONTA o LOT¬ 
TO dovrete inserire nel connettore femmi¬ 
na deirLX.1171 la basetta visibile in fig.15. 
















Fig.21 Disegno a grandezza naturale dei due stampati da inserire nella scheda LX.1171 
(vedi figg.19-20) visti dal lato rame. Il circuito di sinistra siglato LX.1171/B serve per il pro¬ 
gramma Led, mentre quello siglato LX.1171/D serve per i programmi Conta e Lotto. 


tipo Iamp6 - Iamp7 eco. seguite dalle istruzioni .by¬ 
te, perché il programma non funzionerebbe. 

NOTA IMPORTANTE: Come avrete notato, le i- 
struzioni di tipo .byte per accendere i led, che se¬ 
guono le cinque etichette lampi - Iamp2 - ecc., 
sono 8, e così devono sempre rimanere. Se can¬ 
cellate alcune di queste istruzioni oppure ne ag¬ 
giungete altre analoghe, il programma non fun¬ 
zionerà. 

Eseguite le vostre modifiche dovete salvarle, altri¬ 
menti anche se leggerete sul monitor le istruzioni 
che avete appena scritto, il programma non risul¬ 
terà modificato. 

Per salvare le variazioni basterà premere il tasto 
F2: dopo pochi istanti vedrete accendersi la luce 
dell’Hard-Disk, quindi sarete sicuri che il file modi¬ 
ficato è stato aggiornato. 

Se non desiderate salvare le modifiche dovete te¬ 
nere premuto Alt e poi premere F3. 

Comparirà la finestra di fig.7 dove vi verrà chiesto 
se volete salvare (tasto Y) oppure no (tasto N) le 
modifiche apportate. 

Premendo uno qualsiasi di questi tasti tornerete nel 
menu di fig.3. 

Una volta apportate e salvate le modifiche, prima 
di trasferire i dati del programma nelle memorie del 
microprocessore dovete eseguire un’operazione 
supplementare, cioè lanciare il programma as¬ 
sembla, che serve per convertire le istruzioni del 
programma in dati che il microprocessore utilizza 
per eseguire il programma. 


Senza uscire dal listato del programma, dopo aver 
apportato le modifiche ed averle salvate con il ta¬ 
sto F2, premete i tasti Alt+T e di seguito A (vedi 
fig.6). 

In questo modo lo schermo del vostro computer di¬ 
venterà tutto nero e dopo alcuni secondi vedrete 
apparire questa scritta: 

*** SUCCESS *** 

che conferma che l’assemblaggio è stato com¬ 
pletato senza errori. 

Finita l’operazione di assemblaggio, premendo un 
tasto qualsiasi tornerete al listato del programma. 

Se anziché apparire la scritta *** SUCCESS *** 
compare ad esempio: 

ERROR C:\ST62\LED.ASM 256: 

significa che nella riga 256 del file LED.ASM ave¬ 
te involontariamente inserito un errore. 

Nota: Un errore molto comune nel quale si può in¬ 
cappare è quello di scrivere un numero binario con 
un numero di cifre superiore ad 8. Se per esem¬ 
pio scrivete un numero binario a 9 cifre del tipo: 

.byte 110101001 b ; Seconda istruzione 

dopo aver lanciato il programma assembla com¬ 
parirà il messaggio di errore: 

ERROR C:\ST62\LED.ASM 256: 

(81) 8-bit value overflow 

Il numero tra parentesi (81) identifica il tipo di er¬ 
rore e non vi interessa, mentre la scritta 8-bit va- 
























lue overflow significa che avete utilizzato un nu¬ 
mero binario con più di 8 bit 

Per correggere questo errore dovete tornare al li¬ 
stato del programma e per questo basterà preme¬ 
re un tasto qualsiasi. 

Una volta nel listato, poiché l’errore era stato se¬ 
gnalato nella riga 256, dovete portarvi con il cur¬ 
sore su questa riga e controllare che risulti effetti¬ 
vamente scritto un numero di 8 bit (8 cifre). 

Questo errore si verificherà raramente perché scri¬ 
vere un’istruzione così semplice non sarà per voi 
un problema, comunque lo abbiamo voluto segna¬ 
lare, perché se un domani dovesse apparire per un 
vostro programma un qualunque messaggio di er¬ 
rore, sappiate che questo è presente nella riga in¬ 
dicata prima dei due punti (:). 

Per uscire dal file LED.ASM dovete tenere pre¬ 
muto Alt e poi premere F3. Se non avete ancora 
salvato la correzione, comparirà la finestra di fig.7, 
in cui dovrete indicare se volete salvare (tasto Y) 
oppure no (tasto N) le modifiche. 

Premendo Y registrerete queste modifiche, pre¬ 
mendo N invece non le salverete. 

Facciamo presente che premendo uno qualsiasi di 
questi tasti, Y o N, il listato del file LED scompa¬ 
rirà e ritornerete nel menu principale. 

Il FILE STANDARD.ASM 

Come abbiamo già avuto modo di sottolineare, pre¬ 
mendo F3 dal menu principale, oltre ai tre files di 
tipo .ASM contenenti i programmi (-) test per ST62, 
compare un file chiamato STANDARD.ASM, che 
non contiene un programma vero e proprio. 

In questo file trovate l’elenco delle istruzioni che 
devono comparire sempre in ogni programma, e la 
cui conoscenza è basilare se si desidera realizza¬ 
re programmi personali. 

Sono inoltre presenti tantissimi commenti, che vi 
aiuteranno a capire il significato delle varie istru¬ 
zioni e tante note utilissime per realizzare pro¬ 
grammi per ST62 senza incorrere negli errori più 
banali. 

Per visualizzare questo file dovete eseguire di nuo¬ 
vo le operazioni spiegate nel paragrafo Per vede¬ 
re il listato di un programma, e quando compa¬ 
re l’elenco dei files dovete premere Enter, portare 
il cursore sul nome STANDARD.ASM e premere 
di nuovo Enter. 

Questo file risulterà molto utile sia ai più esperti, 
che vogliono cimentarsi nella realizzazione di pro¬ 
grammi senza attendere l’uscita della prossima ri¬ 
vista, sia a chi è alle prime armi, perché potrà ini¬ 


ziare a riconoscere le istruzioni principali che ri¬ 
corrono in qualsiasi programma per ST62. 
Probabilmente a molti di voi queste scritte appari¬ 
ranno ancora oscure e prive di significato, quindi 
non perdete il prossimo numero in cui vi spieghe¬ 
remo il significato di tutte le istruzioni. 

Per TORNARE al DOS 

Quando avete terminato le operazioni di program¬ 
mazione potete uscire dal programma e ritornare 

al DOS. 

Se vi trovate nel menu di fig.3, basterà tenere pre¬ 
muto Alt e poi pigiare X e così sul monitor com¬ 
parirà: 

C:\ST6> 

a questo punto per uscire dalla directory ST6 e lan¬ 
ciare altri programmi dovrete digitare: 

C:\ST6>CD \ poi Enter 

e così comparirà: 

C:\> 

Arrivederci al prossimo numero. 


COSTO DI REALIZZAZIONE 

Costo del kit LX.1171 completo di circuito stampa¬ 
to, dell’integrato 74LS244 (non c’è l’ST62E10 per¬ 
ché inserito nel kit LX.1170) più il quarzo, i pulsanti 
ed il circuito stampato LX.1171/B (vedi fig.14) con 


gli 8 diodi led.€ 12,90 

Il kit LX.1171/D con i due display ed i due transi¬ 
stor BC.327 (vedi fig.15).€ 4,90 

Costo del solo stampato LX.1171.€ 3,72 

Costo del solo stampato LX.1171/B.€ 0,93 

Costo del solo stampato LX.1171/D.€ 1,08 


I prezzi sopra riportati sono già compresi di IVA, 
ma non sono incluse le spese postali di spedizio¬ 
ne a domicilio. 







Come vi abbiamo anticipato nella precedente rivi¬ 
sta, per programmare un ST6, come del resto un 
qualunque altro microprocessore, è assolutamen¬ 
te necessario conoscere le basi del linguaggio di 
programmazione, perché senza queste è impossi¬ 
bile scrivere un programma. 

Tanto per fare un esempio, se vi proponessimo di 
progettare un amplificatore utilizzando un integra¬ 
to operazionale, senza precisare come si collega 
il piedino invertente o quello non invertente o 
quali modifiche vanno apportate per alimentare il 
circuito con una tensione singola anziché duale, 
incontrereste parecchie difficoltà nella sua realiz¬ 
zazione. 


scal - C è avvantaggiato rispetto a chi inizia da “ze¬ 
ro”, anche se come vedrete, tutti i microprocesso¬ 
ri ST6 utilizzano un linguaggio assembler molto 
semplificato. 

PER SCRIVERE un PROGRAMMA 

Prima di scrivere qualsiasi programma è necessa¬ 
rio sapere quali operazioni deve eseguire il micro- 
processore, perché in funzione della memoria oc¬ 
cupata, dovrete scegliere il micro più idoneo. 
Infatti se avete un programma che non supera i 2K, 
potete utilizzare un ST62E10, se invece avete un 
programma che occupa più di 2K e non supera i 


IMPARARE a programmare i 


Evidenziamo questo perché non vogliamo com¬ 
portarci come tanti altri, che spiegano poco o nien¬ 
te ed illudono i loro lettori sostenendo che non c’è 
nulla di più facile che programmare un ST6. 

Prima di insegnarvi a programmare sarà quindi u- 
tile spiegare, anche solo a grandi linee, cosa sono 
un registro e una subroutine, il significato di tut¬ 
te le istruzioni, quali jp - jrr - jrs - Id - cp ecc., e 
come si utilizza una memoria. 

A questo proposito vogliamo sottolineare che non 
è sufficiente imparare a memoria il significato di tut¬ 
te le istruzioni, ma occorre anche sapere come - 
dove - quando utilizzarle, se si vuole che il pro¬ 
gramma funzioni correttamente. 

Non illudetevi pensando di diventare esperti pro¬ 
grammatori in pochi giorni, perché andreste incon¬ 
tro ad una delusione: sono necessari infatti alcuni 
mesi di pratica per acquisire una sufficiente pa¬ 
dronanza della materia. 

Per accelerare l’apprendimento vi suggeriamo di i- 
niziare a leggere i programmi già funzionanti, per¬ 
ché studiare le soluzioni adottate per scrivere una 
subroutine, utilizzare un interrupt, o ancora vedere 
come si sfrutta la memoria, vi sarà di valido aiuto. 
In altre parole, anche se sapete scrivere una lette¬ 
ra o una cartolina, non è detto che siate capaci di 
scrivere un libro giallo o un bel romanzo di avven¬ 
tura, quindi se decidete di dedicarvi all’attività di 
scrittore, dovete prima acquisire un po’ di espe¬ 
rienza facendovi seguire da un letterato o leggen¬ 
do testi d’autore per apprendere come impostare i 
vari capitoli. 

Chi sa già programmare in Basic - Fortran - Pa- 


4K, dovete necessariamente adoperare un 

ST62E20. 

Nelle Tabelle N.1-2 riportiamo per ogni micropro¬ 
cessore la memoria disponibile ed il massimo nu¬ 
mero di ingressi/uscite utilizzabili, cioè il numero 
di piedini che potete adoperare per i segnali. 


TABELLA N.1 micro NON CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62T.10 

2 K 

64 byte 

20 pin 

12 

ST62T.15 

2 K 

64 byte 

28 pin 

20 

ST62T.20 

4 K 

64 byte 

20 pin 

12 

ST62T.25 

4 K 

64 byte 

28 pin 

20 


TABELLA N.2 micro CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62E.10 

2 K 

64 byte 

20 pin 

12 

ST62E.15 

2 K 

64 byte 

28 pin 

20 

ST62E.20 

4 K 

64 byte 

20 pin 

12 

ST62E.25 

4 K 

64 byte 

28 pin 

20 


Quando scrivete un programma, dovete inserire 
tutte le istruzioni nella sequenza in cui volete che 
siano eseguite dal microprocessore. 

Ad esempio, se voleste programmare un robot per 
























MICROPROCESSORI ST6 


Dopo avervi presentato sul N.172/173 un programmatore per micropro¬ 
cessori ST6 ed un circuito per i test, sarete curiosi di conoscere le pro¬ 
cedure per scrivere i vostri programmi, ad esempio per realizzare un o- 
rologio, per pilotare dei display alfanumerici LCD, per realizzare gene¬ 
ratori d’impulsi ecc. Se ci seguirete, cercheremo di spiegarvi con facili 
esempi tutte le istruzioni necessarie per scrivere i programmi per l’ST6. 


cuocere degli spaghetti, dovreste fornirgli nell’ordi¬ 
ne queste istruzioni: 

- Prendi una pentola 

- Riempila per metà di acqua 

- Metti il tutto sul fornello 

- Accendi il gas sotto la pentola 

- Attendi che l’acqua bolla 

- Versaci un po’ di sale 

- Immergi gli spaghetti nell’acqua 

- Attendi 5-6 minuti 

- Spegni il fornello 

- Togli la pentola dal fornello 

- Scola la pasta 

Se vi dimenticate anche una sola di queste istru¬ 
zioni, quale ad esempio quella di accendere il for¬ 
nello, non riuscirete mai a cuocere gli spaghetti. 

E così se vi dimenticate di inserire l’istruzione riem¬ 
pi la pentola con acqua, non potrete mai arriva¬ 
re alla condizione di vedere l’acqua bollire. 

Dunque prima di apprestarvi a scrivere un pro¬ 
gramma dovete sapere: 


Come aprire un file per il programma 
Come scrivere le istruzioni richieste 
Come impostare il programma 
Come utilizzare la memoria 


COME CREARE un FILE SORGENTE 

Chi ha già richiesto il kit LX.1170 del Program¬ 
matore per ST6 pubblicato sulla rivista N.172/173 
avrà ricevuto un dischetto floppy, che oltre a ser¬ 
vire per trasferire un programma dall’Hard-Disk nel¬ 
la memoria di un microprocessore ST6, serve per 
creare i files sorgenti necessari per scrivere qual¬ 
siasi vostro programma. 

Infatti in questo dischetto è stato memorizzato un 
ottimo editor, corredato di tantissime opzioni che 
vi saranno utili per scrivere le istruzioni, per dupli¬ 
carle, per cancellarle ed anche per salvare i files 
modificati; nel floppy è stato inoltre incluso un as¬ 
semblatore. 

Nella rivista precedente (se non ne siete in pos¬ 
sesso potete richiedercela, perché abbiamo anco¬ 
ra delle copie disponibili), vi abbiamo spiegato co- 





Fig.1 Per aprire un nuovo file dovete ri¬ 
chiamare il menù principale e a questo pun¬ 
to se premete il tasto F3 appariranno tutti i 
nomi dei files del programma ST6 con e- 
stensione .ASM. 



Fig.2 Dalla fig.1 premete Enter, poi portate 
il cursore sulla riga STANDARD.ASM e pre¬ 
mete nuovamente Enter. Aprirete così la 
SORGENTE STANDARD per scrivere un 
nuovo programma. 



Fig.3 Per ricopiare la SORGENTE STAN¬ 
DARD dovete assegnarle un altro nome. Per 
fare questo dovete premere i tasti ALT+F 
poi premere il tasto A. Da questa figura si 
passerà alla fig.4. 


me caricare il programma ST6 nel vostro compu¬ 
ter. 

Per richiamare il programma dovete semplicemen¬ 
te digitare: 

C:\ST6>ST6 poi Enter 

e così compare sul monitor il menu principale. 

A questo punto dovete aprire un nuovo file, nel 
quale scrivere il vostro programma. 

Per aiutarvi fin da queste prime fasi, abbiamo in¬ 
serito nel dischetto floppy il file STANDARD.ASM, 
che racchiude l’elenco delle istruzioni che devono 
necessariamente comparire in ogni programma. 
Copiando il file STANDARD con un altro nome, a- 
vrete subito a disposizione la struttura base per 
scrivere il vostro programma. 

Quindi per aprire un nuovo file dovete procedere 
come segue: 

1 ° - Quando appare il menu principale premete il 
tasto funzione F3 (vedi fig.1), poi premete Enter e 
portate il cursore sul nome STANDARD.ASM (ve¬ 
di fig.2), quindi premete ancora Enter. 

2° - Prima di qualsiasi altra cosa, dovete salvare 
questo file con un altro nome, quindi premete i ta¬ 
sti Alt+F e di seguito selezionate l’opzione Save 
as (che significa “salva con nome”) premendo la 
lettera A (vedi fig.3). 

3°- Sul monitor appare una finestra nella quale do¬ 
vete digitare, oltre a C:\ST6\, il nome del vostro 
programma (vedi fig.4). 

Questo nome, che vi servirà quando vorrete tra¬ 
sferire il programma dall’Hard-Disk al micropro¬ 
cessore ST6, non deve mai superare gli 8 carat¬ 
teri. 

Dopo il nome non dovete dimenticarvi di aggiun¬ 
gere l’estensione .ASM, che sta ad indicare che si 
tratta di un programma in assembler. 

Cercate un nome che abbia una logica attinenza 
col programma che scriverete, per poterlo poi fa¬ 
cilmente riconoscere tra gli altri. Per esempio po¬ 
treste chiamare i programmi: 

LED.ASM 
LOTTO.ASM 
OROLOGIO.ASM 
TIMER.ASM ecc. 

4° - Dopo aver scritto il nome per esteso (ad e- 
sempio, C:\ST6\TIMER.ASM) premete Enter, ed in 
















































alto, nella pagina dell’editor visibile in fig.5, vedre¬ 
te apparire la scritta: 

C:\ST6\TIMER.ASM 

che vi conferma che il file chiamato TIMER.ASM è 
stato creato. 


COME ASSEMBLARE un PROGRAMMA 

Importante: Quando avrete terminato di scrivere il 
programma, come più avanti vi spiegheremo, e l’a¬ 
vrete controllato apportando le modifiche necessa¬ 
rie, dovrete assemblarlo, altrimenti non potrete 
memorizzarlo nel microprocessore. 

Per questo motivo, prima di chiudere l’editor, cioè 
il file del programma, premete i tasti Alt+T e di se¬ 
guito il tasto A = assembla (vedi fig.6). 

Se non avete commesso errori, dopo qualche se¬ 
condo apparirà sul monitor la scritta SUCCESS. 

In caso contrario, apparirà un messaggio che vi in¬ 
dicherà il tipo di errore commesso e la riga di i- 
struzione in cui si trova. 

Per correggere l’errore dovete tornare all’editor pre¬ 
mendo un tasto qualsiasi. 

Per trasferire il programma all’interno dell’ST6, se¬ 
guite le istruzioni ampiamente descritte sulla rivista 

N.172/173. 


COME si SCRIVE un’ISTRUZIONE 

Quando scrivete un programma dovete rispettare 
alcune semplici regole che ora vi indicheremo, al¬ 
trimenti quando l’assemblerete compariranno dei 
messaggi relativi agli errori, che dovrete correg¬ 
gere per poter proseguire. 

Ogni istruzione deve essere scritta su una diversa 
riga di programma e deve essere composta da 
un’etichetta, da un’istruzione e da un operando 
dell’istruzione. 

Ad esempio nella riga di programma: 

pippo Idi a,10h 

pippo è l’etichetta 
Idi l’istruzione 
a,10h è l’operando dell’istruzione 


ETICHETTA 

L’etichetta è un riferimento non obbligatorio che 

deve partire sempre dall’estremo sinistro della ri¬ 
ga. 

Un’etichetta serve come punto di riferimento per 
poter ritornare nuovamente, tramite l’istruzione di 



Fig.4 Ammesso che vogliate chiamare il 
nuovo programma TIMER (ricordate che il 
nome non può mai superare gli 8 caratteri) 
scrivete per esteso C:\ST6\TIMER.ASM poi 
premete Enter. 



Fig.5 Una volta creato il file TIMER vedrete 
apparire nella prima riga in alto della fine¬ 
stra blu dell’editor C:\ST6\TIMER.ASM. A 
questo punto potete iniziare a scrivere il vo¬ 
stro nuovo programma. 



Fig.6 Una volta completato il programma 
prima di memorizzarlo neM’ST6 lo dovete 
Assemblare. Premete quindi i tasti ALT+T 
poi il tasto A. Se avete commesso un erro¬ 
re nel programma, vi verrà segnalato. 



































































salto (indicata con la sigla jp, abbreviazione di 
jump), su quella riga di programma. 

Quando scrivete un’etichetta dovete rispettare 
queste regole: 

La parola non deve superare gli 8 caratteri 

Potete scrivere nota - PIPPO - RIF ecc., ma non 
parole che superino gli 8 caratteri. 

L’etichetta non deve iniziare con un numero 

Non potete scrivere Inota - 2nota - 1 PIPPO - 

2PIPPO ecc., ma potete posizionare un numero 
dopo la parola, senza interporre spazi tra parola e 
numero. E’ quindi corretto scrivere notai - PIP- 
POI ecc. 

Non si può usare lo stesso nome due volte 

E’ scorretto definire più etichette con lo stesso no¬ 
me, cioè scrivere PIPPO - PIPPO. Potete usare la 
stessa parola solo se inserite un numero progres¬ 
sivo, ad esempio PIPPOI - PIPP02 - PIPP03 ecc. 

Non si può lasciare alcuno spazio a sinistra 
dell’etichetta 

Se premete spazio, poi scrivete: 

PIPPO 

commettete un errore, quindi dovete partire da si¬ 
nistra senza spazio: 

PIPPO 

Carattere dell’etichetta 

Anche se è possibile scrivere l’etichetta sia in mi¬ 
nuscolo sia in maiuscolo, vi consigliamo di scri¬ 
vere sempre in minuscolo così non vi sbaglierete 
mai. 

Quindi scrivete pippol - pippo2 - nota - rif ecc. 
ISTRUZIONE 

Le istruzioni da inserire dopo l’etichetta sono pro¬ 
prie deH’assembler degli ST6. 

Queste istruzioni devono sempre essere scritte do¬ 
po aver lasciato uno spazio. 


Se è già presente il nome dell’etichetta, dovete co¬ 
munque separare l’istruzione con uno spazio. 
Quindi se avete l’etichetta pippol e l’istruzione 
Idi x,10, dovete scrivere: 

pippol Idi x,10 

Se nella riga di istruzione manca il nome dell’eti¬ 
chetta, dovete comunque lasciare uno spazio : 

Idi x,10 

Data l’importanza di scrivere correttamente l’istru¬ 
zione, vi consigliamo di utilizzare la funzione ta¬ 
bulazione premendo il tasto TAB prima di scrive¬ 
re qualsiasi istruzione. 

In questo modo avrete tutte le istruzioni perfetta¬ 
mente incolonnate ed il programma risulterà più 
comprensibile quando dovrete rileggerlo. 


OPERANDO 

Nella riga riportata precedentemente, cioè: 

Idi x,10 

Idi è l’istruzione, che significa carica 
x,10 è l’operando 

Questa riga indica: carica nella cella di memoria 
X il numero 10. 

L’operando deve sempre essere separato dall’i¬ 
struzione tramite uno spazio, quindi se scrivete: 

ldix,10 

commette un grosso errore, mentre se scrivete: 

Idi x,10 

l’intera istruzione è corretta. 

Dopo l’istruzione e l’operando potete inserire, se 
lo ritenete opportuno, un commento. 


| ETICHETTA 


ISTRUZIONE | 

1 1 

| OPERANDO | 

; 

| COMMENTO RIGA | 


Fig.7 Dovrete sempre ricordare che ogni “riga” di programma è composta da quattro bloc¬ 
chi principali: Etichetta - Istruzione - Operando - Commento. I primi tre blocchi andranno 
tenuti separati tra loro da uno o più SPAZI (o ancora meglio usate il tasto TAB della ta¬ 
stiera), mentre l’ultimo blocco del COMMENTO dovrà essere separato da un punto e vir¬ 
gola. Se non userete l'ETICHETTA dovrete comunque lasciare uno o più spazi, mentre se 
non scriverete il COMMENTO non dovrete mettere il punto e virgola. 













Questo deve essere sempre preceduto da un pun¬ 
to e virgola (;), diversamente il computer segna¬ 
lerà errore. 

Utilizzando l’istruzione precedente potete scrivere: 

Idi x,10; inserire 10 in x 

I commenti possono essere scritti anche all’inizio 
di una riga, ma senza lasciare spazi e ricordando 
di mettere sempre prima un punto e virgola (;). 

Ogni volta che completate un’istruzione dovete 
sempre e necessariamente andare a capo pre¬ 
mendo il tasto Enter. 

Tenete presente che le istruzioni possono essere 
scritte sia in minuscolo sia in maiuscolo: 

Idi x,10 oppure LDI X,10 


COME scrivere i NUMERI 

Nell’esempio sopra riportato noi abbiamo scritto 
x,10, in altre parole abbiamo utilizzato un numero 

decimale. 

Tuttavia può risultare più vantaggioso in alcune i- 
struzioni scrivere i numeri in base esadecimale - 
ottale - binaria. 

Per far capire al computer che tipo di numero a- 
vete inserito, dovete scrivere una lettera come qui 
sotto specificato: 

o oppure O se il numero è ottale 
h oppure H se il numero è esadecimale 
b oppure B se il numero è binario 

Ad esempio: 

lOo = numero ottale 

01 Ah = numero esadecimale 
00100101 b = numero binario 

Se dopo il numero non mettete nessuna lettera, il 
computer considererà questo numero decimale. 
Quando scrivete un numero esadecimale, dovete 
sempre mettere davanti ad ogni numero uno 0 (ze¬ 
ro), quindi 01A - 0ED - 0AC ecc., ed alla fine de¬ 
ve seguire la lettera H, per indicare che il numero 
è esadecimale, quindi i numeri sopra riportati van¬ 
no scritti 01 AH - 0EDH - 0ACH. 

I numeri decimali 

iniziano da 0 e terminano a 255 


I numeri ottali 

iniziano da 0 e terminano a 377 

I numeri esadecimali 

iniziano da 0 e terminano a FF 

I numero binari 

iniziano da 0 e terminano a 11111111 

STRUTTURA di un PROGRAMMA 

Per scrivere un programma per ST6 si devono se¬ 
guire delle precise regole che sono: 

Definire lo spazio in MEMORIA 

Definire le VARIABILI 

Definire i REGISTRI 

Scrivere il PROGRAMMA PRINCIPALE 

Scrivere le SUBROUTINE 

Scrivere eventuali subroutine di INTERRUPT 

Definire i VETTORI di INTERRUPT 

Per facilitarvi, abbiamo inserito nel dischetto 
floppy, che avete ricevuto assieme al program¬ 
matore LX.1170 (vedi rivista N.172/173), un file 
chiamato STANDARD.ASM che vi spiega come 
impostare il programma, dove scrivere le varie i- 
struzioni, come definire lo spazio di memoria ed i 
registri, dove posizionare le subroutine, come ini- 
zializzare l’ST6, insomma tutti i consigli e le infor¬ 
mazioni necessarie per non sbagliare. 

Come abbiamo già descritto nel paragrafo “Come 
creare un file sorgente”, tutte le volte che dovrete 
scrivere un nuovo programma copiate il file STAN¬ 
DARD.ASM con il nome del programma che vole¬ 
te scrivere e tutto risulterà più facile. 

La MEMORIA dell’ST6 

All’interno dei microprocessori tipo ST62E10 - 
ST62T10 - ST62E15 - ST62T15 risultano disponi¬ 
bili per II programma 2K di memoria ROM, men¬ 
tre nei microprocessori ST62E20 - ST62T20 - 
ST62E25 - ST62T25 sono disponibili 4K di me¬ 
moria ROM. 

All’interno di ciascun microprocessore sono pre¬ 
senti anche 64 byte di memoria RAM che servo¬ 
no per i registri e le variabili. 

La memoria ROM mantiene tutte le informazioni, 
cioè il programma, inserite durante la programma¬ 
zione del microprocessore anche in assenza di a- 
limentazione. 

La memoria RAM viene usata per le variabili, cioè 
per i dati che devono essere di volta in volta letti, 
scritti e modificati, e quindi può essere “aggiorna¬ 
ta” dallo stesso microprocessore durante il funzio¬ 
namento del programma. 


La memoria (sia ROM sia RAM) può essere con¬ 
siderata come un insieme di piccole celle ed all’in- 
terno di ognuna può essere inserito un solo dato. 
Per portarvi un esempio pratico, potete paragona¬ 
re queste celle a quelle presenti in un favo per a- 
pi. Quando le api hanno riempito una cella, pas¬ 
sano a riempire la seconda, poi la terza ecc. fino a 
riempire tutto il favo. 

In un microprocessore da 2K ci sono esattamente 
1.828 celle in grado di contenere un programma 
composto da circa 900 - 990 righe di programma. 
In un microprocessore da 4K ci sono esattamente 
3.872 celle in grado di contenere un programma 
composto da circa 1.800 - 2.000 righe di pro¬ 
gramma. 


DEFINIZIONE delle VARIABILI 

Innanzitutto la variabile è un numero, decimale - 
ottale - binario oppure esadecimale, che il mi¬ 
croprocessore può modificare tramite una partico¬ 
lare istruzione. 

Le variabili non vengono inserite nella memoria 
ROM, ma sempre e solo nella memoria RAM; in 
questo modo è possibile variare questi numeri se¬ 
condo le diverse esigenze. 

Ad esempio, per realizzare un orologio servono 3 
variabili, una per le ore, una per i minuti ed una 
per i secondi, che tramite opportune e precise i- 
struzioni, si possono incrementare per ottenere le 
seguenti funzioni. 

La prima variabile dei secondi viene aumentata 
dal programma di 1 per ogni secondo trascorso. 
Raggiunto il numero 60, il programma aumenta di 
1 la seconda variabile dei minuti e porta a 00 la 
prima variabile dei secondi. 

Quando la variabile dei minuti raggiunge il numero 
60, il programma aumenta di 1 la terza variabile 
delle ore e porta a 00 le variabili dei minuti e dei 
secondi. 

Quando la variabile delle ore raggiunge il nume¬ 
ro 24, il programma porta a 00 le tre variabili ore - 

minuti - secondi. 

Quando inserite una variabile dovete ricordare che 
se dopo il numero non mettete nessuna lettera, il 
computer lo considera un numero decimale. 

Per informare il computer che avete inserito un nu¬ 
mero con base diversa da 10, seguite le istruzioni 
spiegate nel paragrafo “Come scrivere i numeri”. 

In ogni programma potete inserire un massimo di 
60 variabili e poiché queste sono situate nelle cel¬ 
le della memoria RAM, dovete dare ad ogni cella 
un numero di riferimento, così da poter ritrovare 
la variabile. 
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Fig.8 Nei microprocessori ST6 tipo E10-T10 
ed E20-T20 sono disponibili due sole por¬ 
te, la A e la B. La porta A è siglata A0-A1- 
A2-A3 mentre la porta B è siglata B0-B1-B2- 
B3-B4-B5-B6-B7. Tutti questi piedini pos¬ 
sono essere utilizzati sia come Entrate sia 
come Uscite. Nei prossimi numeri vi spie¬ 
gheremo come predisporli. 


Questo numero di riferimento si chiama indirizzo 
e poiché ogni variabile occupa una sola cella di 
memoria, queste hanno un numero progressivo. 
Se usate i numeri in base dieci, la prima cella por¬ 
ta il numero 132 e l’ultima il numero 191. 

Se usate i numeri in base sedici, la prima cella por¬ 
ta il numero 084H e l’ultima il numero 0BFH. 

Ricordate che il nome che assegnate alla variabi¬ 
le deve sempre essere scritto partendo da sinistra, 
senza lasciare nessuno spazio, ed a questo no¬ 
me deve seguire, spaziandola, la dicitura .def. Do¬ 
po questa abbreviazione, dovete lasciare un altro 

































































ALIMENTAZIONE 
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Fig.9 Nei microprocessori ST6 tipo E15-T15 
ed E25-T25 sono disponibili tre porte, la A, 
la B e la C. La porta A è siglata A0-A1-A2- 
A3-A4-A5-A6-A7, la porta B è siglata B0-B1- 
B2-B3-B4-B5-B6-B7, mentre la porta C è si¬ 
glata C4-C5-C6-C7. Anche tutti questi pie¬ 
dini possono essere utilizzati sia come En¬ 
trate sia come Uscite. 


spazio e poi scrivere il numero, che rappresenta 
l’indirizzo della cella di memoria in cui volete allo¬ 
care questo dato. 

Ricordatevi inoltre che se assegnate la stessa cella 
di memoria a due diverse variabili, il microproces¬ 
sore non segnalerà nessun errore, ma in questo ca¬ 
so il programma funzionerà in modo anomalo e voi 
non otterrete le funzioni che vi eravate prefissati. 

Per il programma che serve a far funzionare un o- 
rologio, potete definire nel seguente modo le 3 va¬ 
riabili: 


secondi .def 132 
minuti .def 133 
ore .def 134 

Potete definire queste variabili anche con un nu¬ 
mero esadecimale, senza che ciò modifichi il fun¬ 
zionamento dell’orologio: 

secondi .def 084H 
minuti .def 085H 
ore .def 086H 

Come ultima indicazione, tenete presente che le 
variabili vanno definite fin dal principio, vanno cioè 
inserite all’inizio del programma e non a metà o al¬ 
la fine. 

Vi consigliamo di scrivere il nome delle variabili 
sempre in minuscolo. 


I REGISTRI del MICROPROCESSORE 

Nella memoria RAM del microprocessore ST6, ol¬ 
tre allo spazio riservato alle variabili in preceden¬ 
za descritte, sono presenti delle altre celle di me¬ 
moria chiamate registri, che permettono di ese¬ 
guire precise funzioni già definite. 

Ad esempio, c’è un registro che permette di defi¬ 
nire quali piedini delle porte A - B - C vanno utiliz¬ 
zati come ingressi e quali come uscite (vedi figg. 
8-9). 

Questi indirizzi devono essere definiti sempre all’i¬ 
nizio di ogni programma. Questa è un’operazione 
che non dovete eseguire se utilizzate, come ab¬ 
biamo spiegato, il file STANDARD.ASM, perché 
abbiamo già definito noi tutti i registri, così da e- 
vitarvi errori. 

IL REGISTRO ACCUMULATORE 

Nel microprocessore ST6 c’è un particolare regi¬ 
stro chiamato accumulatore ed indicato sempre 
con la lettera a, molto importante, perché esegue 
le seguenti operazioni matematiche: 

fa la somma 
fa la sottrazione 

fa la tavola della verità di un AND 
fa una comparazione tra due numeri 
fa il complemento di un numero 

Tutte queste operazioni matematiche si possono 
eseguire solo con il numero che avete provvedu¬ 
to ad inserire nell’accumulatore; il risultato otte¬ 
nuto subentra poi automaticamente a sostituire il 
numero prima presente nel registro accumulato- 
re. 






































































Ritorniamo all’esempio dell’orologio e supponia¬ 
mo che siano le 10:25:30. 

Poiché la funzione dell’orologio presuppone che si 
debba sempre sommare 1 , tramite l’istruzione Id 
(load) spostiamo nell’accumulatore a il numero pre¬ 
sente nella variabile dei secondi, cioè 30. A que¬ 
sto punto possiamo sommare a questo il numero 
1, ottenendo 31. 

Ora sempre con l’istruzione Id, spostiamo nuova¬ 
mente il risultato dal registro accumulatore alla va¬ 
riabile dei secondi, che di conseguenza risulta o- 

ra 31. 

Trascorso un secondo, si ripete il ciclo di istruzio¬ 
ni: spostiamo il numero dalla variabile dei secon¬ 
di nel registro accumulatore, sommiamo a que¬ 
sto 1 ed il nuovo risultato, 32, lo spostiamo nuo¬ 
vamente nella variabile dei secondi. 

L’intero ciclo appena descritto si riduce a tre istru¬ 
zioni: 

Id a,secondi ; carica i secondi in a 

addi a,1 ; somma ad a il numero 1 

Id secondi,a ; carica somma nella variabile 

REGISTRI SPECIALIZZATI 

All’interno del microprocessore ST6 ci sono dei re¬ 
gistri specializzati che noi abbiamo definito nel no¬ 
stro file STANDARD.ASM con le lettere x - y - v - 
w e che vi potrebbero servire per semplificare par¬ 
ticolari operazioni. 

Ad esempio se voleste ottenere un impulso della 
durata di 1 millisecondo potreste eseguire queste 
istruzioni: 


set 

0,port_b 

; metti a 1 il piedino PB0 

Idi 

x,103 

; assegna 103 a x 

dee 

X 

; sottrai 1 a x 

jrnz 

ripeti 

; ripeti se x non è a 0 

res 

0,port_b 

; metti a 0 il piedino PB0 


Questa sequenza di istruzioni fa sì che, iniziando 
dal numero 103 e continuando a sottrargli 1 fino a 
quando non si è raggiunto lo 0, passi esattamente 

1 millisecondo. 

Il SET di ISTRUZIONI 

Le istruzioni del linguaggio assembler usate dal 
microprocessore ST6 sono molto semplici e pos¬ 
sono essere così suddivise: 

1 ° CARICAMENTO DATI 

LD - spostamento di dati tra due registri 
LDI - caricamento di un numero in un registro 


2° ARITMETICHE 

ADD - somma tra variabile e accumulatore 

ADDI - somma tra numero e accumulatore 

AND - funzione And tra variabile e accumulatore 

ANDI - funzione And tra numero e accumulatore 

CLR - azzera una variabile 

COM - complementa i bit nell’accumulatore 

CP - comparazione tra variabile e accumulatore 

CPI - comparazione tra numero e accumulatore 

DEC - sottrae 1 ad una variabile 

INC - somma 1 ad una variabile 

RLC - sposta una variabile a sinistra con riporto 

SLA - sposta una variabile a sinistra senza riporto 

SUB - sottrazione tra variabile e accumulatore 

SUBÌ - sottrazione tra accumulatore e numero 

3° SALTI CONDIZIONATI sull’ETICHETTA 

JRC - salta se c’è un riporto 
JRNC - salta se non c’è un riporto 

JRZ - salta se l’operazione dà 0 
JRNZ - salta se l’operazione non dà 0 
JRR - salta se un bit è 0 
JRS - salta se un bit è 1 

4° SALTI INCONDIZIONATI sull’ETICHETTA 

CALL - esegui una subroutine 

JP - salta sempre sull’etichetta 

5° SETTAGGIO dei BIT 

SET - metti un bit a 1 
RES - metti un bit a 0 

6° CONTROLLO CPU 

NOP - serve per ottenere dei ritardi 

RET - ritorna da una subroutine 

RETI - ritorna da un interrupt 

STOP - blocca tutte le funzioni del micro 

WAIT - arresta l’esecuzione del programma 

TEMPI di ESECUZIONE 

I tempi per eseguire un’istruzione si calcolano a ci¬ 
cli macchina e vanno da un minimo di 2 cicli ad 
un massimo di 5 cicli macchina. 

Tutte le istruzioni di Caricamenti Dati - Funzioni 
Aritmetiche - Salti Incondizionati - Settaggio Bit 
impiegano 4 cicli macchina. 

Tutte le istruzioni Controllo CPU e le istruzioni 
JRC - JRNC - JRZ - JRNZ dei Salti Condiziona¬ 
ti impiegano 2 cicli macchina. 

Tutte le istruzioni JRR - JRS dei Salti Condizio- 


nati impiegano 5 cicli macchina. 

Il tempo di un ciclo macchina dipende dalla fre¬ 
quenza del quarzo utilizzato per il clock. 

Per calcolare il tempo di un’istruzione potete usa¬ 
re questa formula: 

microsecondi = (13 : MHz quarzo) x N cicli 

Ad esempio, se usate un quarzo da 2 MHz per e- 
seguire un’istruzione aritmetica che necessita di 4 
cicli, il microprocessore per svolgerla impiegherà: 

(13 : 2) x 4 = 26 microsecondi 

Se usate un quarzo da 8 MHz, la stessa istruzio¬ 
ne sarà eseguita in un tempo di: 

(13 : 8) x 4 = 6,5 microsecondi 

Per il clock potete usare dei quarzi di qualsiasi fre¬ 
quenza, da 2,45 - 3,4 - 4,7 - 6,5 - 7 - 8 MHz. Nor¬ 
malmente si utilizza la frequenza massima di 8 MHz 
per rendere più veloce l’esecuzione di un pro¬ 
gramma. 

Non usate mai quarzi superiori agli 8 MHz, per¬ 
ché questa è la frequenza massima accettata 
dall’oscillatore interno del microprocessore ST6. 

COME usare le varie ISTRUZIONI 

Le istruzioni vanno scritte secondo precisi criteri, 
ed è quindi abbastanza facile che un principiante 
incontri qualche difficoltà nell’impostarle. 
Ripetiamo nuovamente che se non mettete il no¬ 
me di un’etichetta dovete sempre lasciare uno 
spazio prima di scrivere l’istruzione o, ancora me¬ 
glio, premete il tasto TAB, così da avere tutte le i- 
struzioni incolonnate. 

Per ognuna delle istruzioni utilizzate dal linguaggio 
di programmazione Assembler, diamo di seguito u- 
na semplice spiegazione correlata da un esempio. 

ADD 

Per eseguire una somma tra il numero presente 
nella variabile ed il numero presente nell’accu¬ 
mulatore, dovete scrivere l’istruzione in questo 
modo: 

add a,secondi 

Per questa istruzione abbiamo usato come varia¬ 
bile il nome secondi, ma potevamo utilizzare un 
nome diverso, a patto che fosse stato sempre di 8 

caratteri, come ad esempio gradi - metri - litri ecc. 
Se nell’accumulatore è presente il numero 22 e 
nella variabile secondi è presente il numero 15, 


dopo questa istruzione nell’accumulatore a è pre¬ 
sente il numero 37, perché 22 + 15 = 37. 


ADDI 

Questa istruzione è identica alla precedente con la 
sola differenza che il numero da sommare a quel¬ 
lo presente nel registro accumulatore non è pre¬ 
so dalla variabile, ma immesso direttamente da voi. 
Ad esempio, se al numero presente nell’accumu¬ 
latore, che potrebbe essere 37, volete sommare il 
numero 30, dovrete scrivere: 

addi a,30 

Dopo questa istruzione nell’accumulatore a è pre¬ 
sente il numero 30 + 37 = 67. 


AND 

Questa istruzione permette di eseguire un’opera¬ 
zione AND tra il numero contenuto nell’accumula¬ 
tore e quello nella variabile. 

Per farvi comprendere meglio come viene effet¬ 
tuata questa operazione, riportiamo la tavola del¬ 
la verità con i numeri binari. 

Tavola della verità 

accumulatore 0 0 11 

variabile 0 10 1 

risultato 0 0 0 1 

Secondo questa tavola, quando è presente un va¬ 
lore logico 1 sia nell’accumulatore sia nella va¬ 
riabile, si ha come risultato 1 ; in ogni altra condi¬ 
zione si ha sempre come risultato 0. 

L’istruzione va scritta così: 

and a,secondi 

Se nella variabile secondi è presente il numero 
decimale 30, che convertito in binario è uguale a 
00011110, e nell’accumulatore è presente il nu¬ 
mero decimale 25, che convertito in binario è u- 
guale a 00011001, il risultato dell’operazione AND 
tra questi numeri è: 

00011110 

00011001 

00011000 risultato 

che corrisponde al numero decimale 24. 




ANDI 

A differenza della precedente, questa istruzione e- 
segue un’operazione AND tra il numero contenuto 
nell’accumulatore ed un numero binario scritto 
direttamente da voi sulla stessa riga dell’istruzione. 
Quando nell’accumulatore e nel numero inserito 
è presente un valore logico 1 si ha come risultato 

I ; in ogni altra condizione si ha sempre come ri¬ 
sultato 0. 

Ammesso di avere nell’accumulatore il numero bi¬ 
nario 00011110 e di voler eseguire l’operazione 

AND con il numero binario 11111001, l’istruzione 
va scritta: 

andi a,11111001B 

Come avrete notato, alla fine di questo numero ab¬ 
biamo messo una B affinché il computer possa ri¬ 
conoscere che il numero è binario. 

II risultato di questa operazione è: 

00011110 

11111001 

00011000 risultato 

Le due funzioni AND e ANDI possono essere uti¬ 
lizzate per modificare il livello logico sugli otto pie¬ 
dini di uscita di una porta del microprocessore. 
Sapendo su quali di questi piedini è presente un li¬ 
vello logico 0 e su quali è presente un livello lo¬ 
gico 1 , è possibile accendere ad esempio dei dio¬ 
di led. 

Nel nostro esempio, poiché il risultato è 00011000, 
saranno spenti i primi tre diodi led, accesi i suc¬ 
cessivi due e spenti gli ultimi tre. 

Per portare il risultato dell’istruzione ANDI sulla 
porta di uscita B, bisogna scrivere questa istru¬ 
zione: 

ld port_b,a 

che in pratica significa: carica (ld) sulla porta B il 
risultato contenuto nell’accumulatore a. 


CALL 

Questa istruzione viene adoperata quando si vuo¬ 
le far eseguire al microprocessore una subrouti¬ 
ne, cioè un parte di programma identificata con 

un’etichetta. 

Le subroutine sono utili per eseguire più volte lo 
stesso set di istruzioni. 


Ad esempio potrebbe verificarsi di dover ripetere 
più volte la seguente funzione di ritardo. 

ritardo Idi x,103 ; assegna 103 a x 

ripeti dee x ; sottrai 1 a x 

jrnz ripeti ; ripeti se x non è a 0 

ret ; ritorna al programma 

Tutte le volte che vorrete ripetere queste istruzioni 
in una parte del programma, basterà scrivere: 

cali ritardo ; chiama subroutine ritardo 

Come potete notare con due sole parole, cali ri¬ 
tardo, farete ripetere esattamente le stesse istru¬ 
zioni contrassegnate dall’etichetta ritardo, senza 
bisogno di riscriverle. 

In questo modo non solo eviterete di occupare al¬ 
tra memoria nel microprocessore, ma soprattutto 
non correrete il rischio di compiere qualche errore 
nel riscrivere le istruzioni. 

Eseguita la subroutine ritardo, il microprocessore 
proseguirà con le istruzioni successive alla riga 
cali ritardo, perché alla fine della subroutine è 
presente l’istruzione ret, che significa: ritorna al 
programma nella riga successiva alla quale era 
scritto cali ritardo. 


CLR 

Questa istruzione serve per portare a 0 una varia¬ 
bile. 

Per spiegarci meglio riconsideriamo il programma 
per realizzare un orologio. 

Per ottenere la funzione orologio è necessario che 
il numero delle ore riparta da zero quando si è rag¬ 
giunto il numero 24; allo stesso modo quando i mi¬ 
nuti ed i secondi hanno raggiunto il numero 60, 
devono ripartire a contare da zero. 

Quando volete che le variabili chiamate ore - mi¬ 
nuti - secondi diventino 0 dovete scrivere: 

clr ore 
clr minuti 
clr secondi 

La funzione CLR può essere usata anche per az¬ 
zerare il registro accumulatore scrivendo sempli¬ 
cemente: 

clr a 

In questo modo cancellerete eventuali numeri ri¬ 
masti nell’accumulatore da un’operazione prece¬ 
dente. 



COM 


Questa funzione serve per complementare il nu¬ 
mero binario presente nell’accumulatore. 

In altre parole, questa istruzione inverte ogni sin¬ 
golo bit, quindi dove c’è 0 si ha 1 e dove c’è 1 si 

ha 0. 

Se nell’accumulatore è presente il numero bina¬ 
rio 00011000 scrivendo: 

corri a 

il contenuto dell’accumulatore diventerà 11100111. 


CP 

Questa istruzione confronta il numero contenuto 
nell’accumulatore con quello presente nella va¬ 
riabile. 

Da questo confronto il microprocessore ricava que¬ 
ste tre sole condizioni: 

- Il numero dell’accumulatore è minore rispetto a 
quello della variabile. 

- il numero dell’accumulatore è uguale a quello 
della variabile. 

- il numero dell’accumulatore è maggiore rispet¬ 
to a quello della variabile. 

Questo confronto è utile quando occorre far com¬ 
piere dei salti condizionati al programma, per e- 
seguire le operazioni che desiderate. 

Prendiamo ancora una volta l’esempio dell’orolo¬ 
gio. 

Quando il numero nella variabile secondi giunge 
a 60, bisogna ripartire da 0 ed aumentare di 1 il 
numero nella variabile minuti. 

Quando il numero nella variabile minuti giunge a 
60 , bisogna ripartire da 0 ed aumentare di 1 il nu¬ 
mero nella variabile ore. 

Quando il numero nella variabile ore giunge a 24, 
bisogna riportare a 0 le variabili ore - minuti - se¬ 
condi. 

Il programma per eseguire queste funzioni va scrit¬ 
to nel seguente modo: 


ine 

secondi 

incrementa di 1 i secondi 

Idi 

a,60 

carica in a il numero 60 

cp 

a,secondi 

confronta a con variabile sec. 

jrnz 

fine 

salto condizionato a fine 

clr 

secondi 

azzera i secondi 

ine 

minuti 

incrementa di 1 i minuti 

Idi 

a,60 

carica in a il numero 60 

cp 

a,minuti 

confronta a con variabile min. 

jrnz 

fine 

salto condizionato a fine 


clr 

minuti 

; azzera i minuti 

ine 

ore 

; incrementa di 1 le ore 

Idi 

a,24 

; carica in a il numero 24 

cp 

a,ore 

; confronta a con variabile ore 

jrnz 

fine 

; salto condizionato a fine 

clr 

ore 

; azzera le ore 

; fine dell’incremento 


Quando il numero dei secondi è diverso da 60, 
numero caricato nell’accumulatore, si fa fare al 
programma un salto condizionato, cioè si salta 
alla riga di programma con l’etichetta chiamata fi¬ 
ne. 

Quando il numero dei secondi è uguale a 60 que¬ 
sto salto non avviene, quindi il programma passa 
alla riga successiva aumentando di 1 la variabile 
dei minuti ed azzerando quella dei secondi. 

Fino a quando la variabile dei minuti non avrà rag¬ 
giunto il numero 60, si fa fare un salto condizio¬ 
nato sull’etichetta fine. 

Quando il numero dei minuti è uguale a 60 que¬ 
sto salto non avviene, quindi il programma passa 
alla riga successiva aumentando di 1 la variabile 
delle ore ed azzerando quella dei minuti. 

Il programma confronta il numero presente in que¬ 
sta variabile con quello presente nell’accumula¬ 
tore, che è 24, e quando nella variabile è presente 
il numero 24, il programma passa alla riga suc¬ 
cessiva, vedi clr ore, per azzerare la variabile o- 
re. 

Se il microprocessore ripete questo programma o- 
gni secondo, compiendo nel frattempo altre istru¬ 
zioni di programma, avrete ottenuto la funzione o- 
rologio. 


CPI 

Questa istruzione si differenzia dalla precedente 
perché confronta il numero contenuto nell’accu¬ 
mulatore con un numero direttamente scritto da 
voi. 

Da questo confronto il microprocessore ricava 
sempre queste tre sole condizioni: 

- il numero dell’accumulatore è minore rispetto a 
quello della variabile. 

- il numero dell’accumulatore è uguale a quello 
della variabile. 

- il numero dell’accumulatore è maggiore rispet¬ 
to a quello della variabile. 

Questo confronto è utile quando occorre far com¬ 
piere dei salti condizionati al programma, per e- 
seguire le operazioni che desiderate. 




Ad esempio, se volete realizzare un termostato 
che disecciti un relè quando la temperatura ha 
raggiunto i 20 gradi, un modo per scrivere le i- 
struzioni potrebbe risultare il seguente: 

ld a,gradi ; carica in a i gradi 
cpi a,20 ; compara i gradi con numero 20 

jrc funz ; salta a funz se minore di 20 

res 7,port_b ; diseccita il relè 
funz ; non diseccitare il relè 

La temperatura prelevata da una sonda viene 
messa nell’accumulatore per essere poi compa¬ 
rata con il numero 20. 

Se la temperatura è minore di 20, il programma 
salta all’etichetta siglata funz e quindi il relè non 
si diseccita. 

Quando la temperatura ha raggiunto i 20 gradi, il 
microprocessore passa ad eseguire l’istruzione 
presente nella quarta riga, cioè si resetta, portan¬ 
do a livello logico 0 il piedino 7 della porta B. In 
questo modo il relè collegato su questo piedino si 
diseccita. 


DEC 

Questa istruzione serve per decrementare di 1 il 
numero presente nella variabile specificata di se¬ 
guito. 

Ad esempio, se volete che trascorsi 40 minuti si 
disecciti un relè, dovete scrivere il programma nel 
seguente modo: 


quindi il numero presente nella variabile secondi 
viene aumentato di 1. 


NOTA importante per 
le istruzioni DEC e INC 

Quando utilizzate queste istruzioni dovete tenere 
presente quanto segue: 

- un ulteriore decremento (istruzione DEC) quan¬ 
do la variabile è arrivata al numero decimale 0 
porta il valore della variabile a 255. 

- un ulteriore incremento (istruzione INC) quando 
la variabile è arrivata al numero decimale 255 por¬ 
ta il valore della variabile a 0. 


JP 

Questa istruzione consente di effettuare un salto 
incondizionato in un punto qualsiasi del pro¬ 
gramma marcato da un’etichetta. 

Ad esempio, se dovete far lampeggiare un diodo 
led con una cadenza di 1 secondo, dovete scri¬ 
vere: 

inizio ; etichetta 

com a ; se acceso spegni o viceversa 

ld port_b,a ; sposta su b quello che c’è in a 

cali ritardo ; chiama funzione ritardo 

jp inizio ; ripeti funzione dall’inizio 

Vi ricordiamo che ritardo è un’etichetta (vedi i- 
struzione CALL). 


Idi tempo,40 


dee tempo 
ld a,tempo 
cpi a,0 
jrnz funz 
res 7,port_b 

funz 


carica in tempo il numero 40 

decrementa la variabile tempo 
carica in a la variabile tempo 
confronta a con il numero 0 
se è diverso da 0 salta in funz 
diseccita relè 
non diseccitare il relè 


Dopo avere caricato il numero 40 nella variabile 
tempo, dovete completare il programma (spazio 
indicato con puntini) per far eseguire al program¬ 
ma un decremento ogni 60 secondi. 


JRC 

Questa istruzione viene sempre inserita nei pro¬ 
grammi dopo un’istruzione CP o CPI per effettua¬ 
re un salto condizionato. 

Se dalla comparazione il microprocessore rileva 
che il numero presente nell’accumulatore è mi¬ 
nore di quello presente nella variabile, viene ef¬ 
fettuato un salto sull’etichetta. 

Nella funzione CPI, in cui vi abbiamo presentato un 
esempio di programma per termostato, avete tro¬ 
vato utilizzata l’istruzione JRC: 


INC 

Questa istruzione serve per aumentare di 1 il nu¬ 
mero presente nella variabile specificata di segui¬ 
to. 

Ritornando all’esempio scritto per l’istruzione CP, 
la prima riga conteneva l’istruzione: 

ine secondi ; incrementa la variabile secondi 


ld 

cpi 

jrc 

res 

funz 


a,gradi 
a,20 

; carica nell’accumul. i gradi 
; compara i gradi con numero 20 

funz 

; salta a funz se minore di 20 

7,port b 

; diseccita il relè 

; non diseccitare il relè 


In questo caso il salto viene effettuato sull’eti¬ 
chetta siglata funz fino a quando la temperatura 
non raggiunge i 20 gradi. 





Nota importante: Il salto jrc riesce a raggiungere 
un’etichetta solo se questa si trova ad una distanza 
pari a circa 8 righe di programma. 

Se eseguite un salto jrc su un’etichetta che dista 
più di 8 righe, quando assemblerete il program¬ 
ma, vi verrà segnalato errore con la scritta “5-bit 
displacement overflow”. 


JRNC 

Questa istruzione viene sempre inserita dopo un’i¬ 
struzione CP o CPI per effettuare un salto condi¬ 
zionato. 

Se dalla comparazione il microprocessore rileva 
che il numero presente nell’accumulatore è mag¬ 
giore oppure uguale a quello presente nella va¬ 
riabile, viene effettuato un salto sull’etichetta. 
Nella funzione CPI il relè si diseccitava quando la 
temperatura superava i 20 gradi; se ora volete che 
Il relè si disecciti quando la temperatura scende 
sotto i 20 gradi, dovete modificare nella terza riga 
l’istruzione jrc funz con la scritta jrnc funz, come 
qui sotto riportato: 

ld a,gradi ; carica nell’accumul. i gradi 
cpi a,20 ; compara i gradi con numero 20 

jrnc funz ; salta a funz se maggiore di 20 

res 7,port_b ; diseccita il relè 
funz ; non diseccitare il relè 

In questo caso il salto viene effettuato sull’eti¬ 
chetta siglata funz solo se la temperatura è mag¬ 
giore o uguale a 20 gradi. 

In pratica si ottiene la funzione opposta quella che 
si otteneva con l’istruzione jrc. 

Nota importante: Il salto jrnc riesce a raggiunge¬ 
re un’etichetta solo se questa si trova ad una di¬ 
stanza pari a circa 8 righe di programma. 

Se eseguite un salto jrnc su un’etichetta che di¬ 
sta più di 15 righe, quando assemblerete il pro¬ 
gramma, vi verrà segnalato errore con la scritta “5- 
bit displacement overflow ”. 


JRNZ 

Questa istruzione viene sempre inserita nel pro¬ 
gramma dopo un’istruzione CP o CPI per effettuare 
un salto condizionato. 

Se dalla comparazione il microprocessore rileva 
che il numero presente nell’accumulatore è di¬ 
verso da quello presente nella variabile, viene ef¬ 
fettuato un salto sull’etichetta. 


Nell’istruzione DEC avevamo riportato un esem¬ 
pio per far diseccitare un relè dopo 40 minuti. 

Idi tempo, 40 ; carica in tempo il numero 40 

dee tempo ; decrementa la variabile tempo 
ld a, tempo ; carica in a la variabile tempo 
cpi a, 0 ; confronta a con il numero 0 

jrnz funz ; se è diverso da 0 salta in funz 

res 7, port_b ; diseccita relè 
funz ; non diseccitare il relè 

Poiché nella variabile abbiamo messo il numero 
40 ed il microprocessore decrementa questo nu¬ 
mero di 1, avremo via via 39 - 38 - 37 ecc. 

Dopo ogni decremento il numero presente nella va¬ 
riabile viene comparato con il numero 0 e fino a 
quando il numero nella variabile è diverso da 0, vie¬ 
ne effettuato il salto nella riga funz ed il program¬ 
ma non esegue la successiva istruzione che di¬ 
seccita il relè. 

Solo quando il numero presente nella variabile è 
uguale a 0, il microprocessore passa ad eseguire 
l’istruzione successiva e diseccita il relè. 

Nota importante: Il salto jrnz riesce a raggiunge¬ 
re un’etichetta solo se questa si trova ad una di¬ 
stanza pari a circa 8 righe di programma. 

Se eseguite un salto jrnz su un’etichetta che di¬ 
sta più di 8 righe, quando assemblerete il pro¬ 
gramma, vi verrà segnalato errore con la scritta 
“5-bit displacement overflow”. 

JRZ 

Questa istruzione viene sempre inserita in un pro¬ 
gramma dopo un’istruzione CP o CPI per effettuare 
un salto condizionato. 

Se dalla comparazione il microprocessore rileva 
che il numero presente nell’accumulatore è u- 
guale a quello presente nella variabile, viene ef¬ 
fettuato un salto sull’etichetta. 

L’esempio riportato nell’istruzione DEC permette¬ 
va di diseccitare un relè dopo 40 minuti. 

Di seguito potete vedere le modifiche che abbiamo 
apportato al programma per usare l’istruzione JRZ. 


Idi 

tempo,0 

; carica in tempo il numero 0 




ine 

tempo 

; incrementa la variabile tempo 

ld 

a,tempo 

; carica in a la variabile tempo 

cpi 

a,40 

; confronta a con il numero 40 

i rz 

funz 

; se è uguale salta in funz 

ÌP 

fine 

; se non è uguale salta in fine 

funz 


; prosegui alla riga dopo 

res 

7,port_b 

; diseccita il relè 

fine 


; non diseccita il relè 


In questo caso abbiamo messo nella variabile il 
numero 0, poi avendo dato l’istruzione per incre- 






meritare questo numero di 1 , avremo via via 0 -1 

-2-3 ecc. 

Tutte le volte che viene effettuato un incremento, 
il numero presente nella variabile tempo viene 
comparato con il numero 40 e fino a quando que¬ 
sti due numeri sono diversi viene effettuato il sal¬ 
to sull’etichetta fine ed il relè non si diseccita. 
Solo quando il numero presente nella variabile è u- 
guale a 40, il microprocessore compie un salto 
sull’etichetta funz ed esegue l’istruzione successi¬ 
va diseccitando il relè. 

Nota importante: Il salto jrz riesce a raggiungere 
un’etichetta solo se questa si trova ad una distanza 
pari a circa 8 righe di programma. 

Se effettuate un salto jrz su un’etichetta che dista 
più di 8 righe, quando assemblerete il program¬ 
ma, vi verrà segnalato errore con la scritta “5-bit 
displacement overflow”. 


JRR 

Questa istruzione serve per controllare se una ci¬ 
fra di un numero binario si trova a livello logico 

0 e quando si rileva questa condizione viene effet¬ 
tuato un salto. 

L’istruzione JRR può risultare utile per controllare 
se il piedino d’ingresso di una qualsiasi porta A- 
B-C si trova a livello logico 0 o a livello logico 1 

(vedi figg.10-11). 

Come sapete ogni porta da 8 bit è numerata 0A - 
1 A- 2A - 3A ecc. 0B - 1B - 2B - 3B ecc. 

Per controllare quando l’interruttore posto sulla 
porta 6B è chiuso (vedi fig.12), e fare in modo che 
quando si riscontra questa condizione si ecciti un 
relè di allarme posto sulla porta d’uscita 2A, do¬ 
vete scrivere l’istruzione in questo modo: 


jrr 

6, port_b, eccita 

; controlla porta 6B 

ÌP 

fine 

; va a fine se 6B è a 1 

eccita 


; etichetta per proseguire 

set 

2,port_a 

; eccita il relè su 2A 


fine ; non eccitare il relè 

In questa istruzione è necessario fare un doppio 
salto: il primo serve ad eccitare il relè se il l’inter¬ 
ruttore applicato sulla porta 6B è chiuso, il se¬ 
condo (jp fine) serve a non eccitare il relè nel ca¬ 
so in cui l’interruttore non risulti chiuso. 

Se non avessimo inserito l’istruzione jp fine, il mi¬ 
croprocessore avrebbe proseguito con le istruzio¬ 
ni successive ed avrebbe ugualmente eccitato il 
relè anche se l’interruttore non fosse stato chiuso. 

Nota importante: Il salto jrr riesce a raggiungere 
un’etichetta solo se questa si trova ad una distanza 
pari a circa 60 righe di programma. 



Fig.10 Le istruzioni JRR e JRS possono es¬ 
sere utili per controllare se le porte A-B-C 
utilizzate come ingressi sono a “livello lo¬ 
gico 1” oppure a “livello logico 0”. Usando 
l’istruzione JRR avviene un “salto” se sul¬ 
la porta d’ingresso è presente un “livello lo¬ 
gico 0”, mentre usando l’istruzione JRS il 
“salto” avviene se sulla porta d’ingresso è 
presente un “livello logico 1”. 



Fig.11 Dopo che vi avremo insegnato come 
predisporre una porta come Entrata, potre¬ 
te collegarle degli interruttori o dei pulsan¬ 
ti rivolti verso “massa” (vedi fig.10) o ver¬ 
so il “positivo” (vedi fig.11) oppure l’uscita 
di una porta Nand - Nor - Or ecc. per con¬ 
trollare il loro livello logico. Nota: Sui vari 
ingresso dovrete collegare delle resistenze 
con valori compresi tra 3.300 -100.000 ohm. 


























































JRS LD 


Questa istruzione serve per controllare se una ci¬ 
fra di un numero binario si trova a livello logico 

1 e quando si rileva questa condizione viene effet¬ 
tuato un salto. 

L’istruzione JRS può essere utile per controllare se 
il piedino d’ingresso di una qualsiasi porta A-B- 
C si trova a livello logico 0 o a livello logico 1 
(vedi figg. 10-11). 

Se volete controllare che l’interruttore posto sulla 
porta 6B risulti chiuso (vedi fig.13) e quando si ri¬ 
scontra questa condizione, eccitare un relè di al¬ 
larme posto sulla porta d’uscita 2A, dovete scri¬ 
vere l’istruzione in questo modo: 


jrs 6,port_b,eccita ;controlla porta 6B 

jp fine ; va a fine se 6B è a 0 

eccita ; etichetta per proseguire 

set 2,port_a ; eccita il relè su 2A 

fine ; non eccitare il relè 


In questa istruzione è necessario compiere un dop¬ 
pio salto: il primo serve ad eccitare il relè se l’in¬ 
terruttore applicato sulla porta 6B è chiuso, il se¬ 
condo (jp fine) serve a non eccitare il relè nel ca¬ 
so in cui l’interruttore non risulti chiuso. 

Se non avessimo inserito l’istruzione jp fine, il mi¬ 
croprocessore avrebbe proseguito con le istruzio¬ 
ni successive ed avrebbe ugualmente eccitato il 
relè anche se l’interruttore non fosse stato chiuso. 


Nota importante: Il salto jrs riesce a raggiungere 
un’etichetta solo se questa si trova ad una distanza 
pari a circa 60 righe di programma. 


Questa istruzione serve per caricare il numero 
contenuto in una variabile nell’accumulatore o vi¬ 
ceversa. 

Nella funzione CPI, in cui abbiamo riportato un e- 
sempio per far diseccitare un relè quando la tem¬ 
peratura supera i 20 gradi, la comparazione vie¬ 
ne effettuata solo con il numero presente nell’ac¬ 
cumulatore, quindi abbiamo dovuto inserire all’in- 
terno dell’accumulatore il numero che era presen¬ 
te nella variabile chiamata gradi: 

Id a,gradi ; carica nell’accumul. i gradi 

cpi a,20 ; compara i gradi con numero 20 

jrnc funz ; salta a funz se maggiore di 20 

res 7,port_b ; diseccita il relè 
funz ; non diseccitare il relè 

Se la variabile gradi contiene il numero 15, dopo 
l’istruzione Id a,gradi anche il numero presente 
nell’accumulatore avrà un valore di 15. 

LDI 

Questa istruzione serve per caricare in una varia¬ 
bile oppure nell’accumulatore un qualsiasi nu¬ 
mero da voi prescelto e compreso tra 0 e 255. 
Nell’istruzione DEC abbiamo riportato un esempio 
per diseccitare un relè dopo 40 minuti. Questo 
numero va quindi inserito nella variabile tempo co¬ 
me qui sotto riportato: 


Idi 

tempo,40 

; carica in tempo il numero 40 

dee 

tempo 

; decrementa la variabile tempo 

Id 

a,tempo 

; carica in a la variabile tempo 

cpi 

a,0 

; confronta a con il numero 0 

jrnz 

funz 

; se è diverso salta in funz 

res 

7,port_b 

; diseccita relè 

funz 


; non diseccitare il relè 



Fig.12 Nel programma riportato al paragrafo 
JRR il relè si eccita ogni volta che corto¬ 
circuitate verso “massa” l’interruttore po¬ 
sto sulla porta 6B. In questo modo sulla 
porta di uscita 2A ritroverete un livello lo¬ 
gico 1 che polarizzerà il transistor. 



Fig.13 Nel programma riportato al paragrafo 
JRS il relè si eccita ogni volta che collega¬ 
te verso il “positivo” l’interruttore posto 
sulla porta 6B. In questo modo sulla porta 
di uscita 2A ritroverete un livello logico 1 
che polarizzerà il transistor. 































Dopo l’istruzione Idi tempo,40 scritta nella prima 
riga, la variabile tempo è uguale a 40. 

NOP 

Questa istruzione viene usata pochissimo, perché 
serve solamente per ottenere un ritardo di qual¬ 
che microsecondo. Infatti fa eseguire al micro- 
processore 2 cicli macchina a vuoto. 

Per eseguire questa funzione è sufficiente scrive¬ 
re, dopo aver lasciato uno spazio, la parola NOP; 
scrivendola più volte aumenterete il ritardo. 

Se nel microprocessore avete utilizzato un quarzo 
da 8 MHz, che esegue 1 ciclo macchina in un tem¬ 
po di 1,625 microsecondi, e scrivete: 


nop 

; ritardo 3,25 microsec. 

nop 

; ritardo 3,25 microsec. 

nop 

; ritardo 3,25 microsec. 


otterrete un ritardo totale di 9,75 microsecondi. 


SET 

Questa istruzione serve per forzare ad un livello 
logico 1 il bit di una variabile. 

Nell’istruzione JRS abbiamo riportato un esempio 
per eccitare un relè ogni volta che il pulsante po¬ 
sto sulla porta 6B viene pigiato. 

Nella riga in cui è posta la funzione set 2,port_a, 
viene forzata l’uscita 2 della porta A a livello lo¬ 
gico 1 , in modo che provveda ad eccitare il relè. 



jrs 

6, port_b,eccita 

; controlla porta 6B 


jP 

fine 

; va a fine se 6B è a 0 

eccita 

set 

2,port_a 

; etichetta per proseguire 
; eccita il relè su 2A 

fine 



; non eccitare il relè 


In pratica l’istruzione SET compie l’operazione in¬ 
versa all’istruzione RES. 


RET 


RES 

Questa istruzione serve per forzare ad un livello 
logico 0 il bit di una variabile. 

Nella funzione CPI abbiamo riportato un esempio 
per diseccitare un relè quando la temperatura su¬ 
pera i 20 gradi. Questa operazione è compiuta dal¬ 
la istruzione res a cui bisogna specificare di se¬ 
guito quale porta deve resettare (nel nostro e- 
sempio è la 7,port_b). 

Id a,gradi ; carica nell’accumul. i gradi 

cpi a,20 ; compara i gradi con numero 20 

jrnc funz ; salta a funz se maggiore di 20 

res 7,port_b ; diseccita il relè 

funz ; non diseccitare il relè 

Ammettendo che tutte le uscite della porta B sia¬ 
no a livello logico 1 , cioè: 

11111111 

Il programma modificherà il solo bit 7 della porta 
B, cioè il primo bit a sinistra, quindi vi ritroverete 
con: 


Questa istruzione viene posta alla fine di una su¬ 
broutine per comunicare al microprocessore di ri¬ 
tornare nel punto del programma in cui questa su¬ 
broutine è stata chiamata. 

Nell’istruzione CALL abbiamo riportato una su¬ 
broutine per ottenere un ritardo, cioè: 

ritardo Idi x,103 ; assegna 103 a x 

ripeti dee x ; sottrai 1 a x 

jrnz ripeti ; ripeti se x non è a 0 

ret ; ritorna al programma 

Volendo ottenere un ritardo dovete richiamare la 
subroutine chiamata ritardo scrivendo: 

cali ritardo ; chiama subroutine ritardo 

Alla fine della subroutine abbiamo posto l’istru¬ 
zione RET per far tornare il programma alla riga 
posta di seguito all’istruzione cali ritardo. 

Vi ricordiamo che al termine della subroutine oc¬ 
corre sempre mettere l’istruzione RET, diversa- 
mente il programma non ritornerà nel punto in cui 
abbiamo chiamato la subroutine, ma proseguirà 
con le righe successive, senza segnalare nessun 
errore, ma causando anomalie nel funzionamento 
del programma. 


01111111 

Se voleste azzerare oltre il piedino 7 della porta B 
anche i piedini 6 - 5, dovreste scrivere: 

res 7,port_b 
res 6,port_b 
res 5,port_b 

Vi ricordiamo che il numero di bit per ogni porta va 

da 0 a 7. 


RETI 

Questa istruzione viene utilizzata alla fine di parti¬ 
colari tipi di subroutine che si chiamano interrupt 
e che sono identificati con le etichette: 

ad_int ; serve per il convertitore A/D 

timjnt ; serve per il timer 

BCJnt ; serve per le porte B-C 

AJnt ; serve per la porta A 

nmi_int ; serve per il piedino nmi 


Dopo una di queste etichette, si interrompono mo¬ 
mentaneamente le funzioni del programma princi¬ 
pale e vengono eseguite le istruzioni che si trova¬ 
no dopo l’interrupt. 

Alla fine di questa subroutine di interrupt dovre¬ 
te inserire l’istruzione RETI per ritornare al pro¬ 
gramma principale, nel punto in cui si trovava pri¬ 
ma dell interruzione forzata. 

Come noterete, nel microprocessore ST6 c’è un 
piedino chiamato appunto nmi (corrisponde al pie¬ 
dino 5) sul quale potete collegare un pulsante (ve¬ 
di fig.14) che potrete usare per interrompere for¬ 
zatamente una funzione. 

Ammettiamo che abbiate scritto un programma per 
l’automazione di un trapano e mentre questo sta 
eseguendo la foratura, si spezzi la punta. 

In questo caso dovete immediatamente interrom¬ 
pere il programma e togliere la tensione di alimen¬ 
tazione dal trapano per sostituire la punta. 

Il programma va scritto nel seguente modo: 

nmijnt ; etichetta nmi di interrupt 

res 5,port_b ; resetta la porta 5B 

reti ; termine subroutine 

La porta 5B è quella che eccita o diseccita il tele¬ 
ruttore che alimenta il trapano. 


RLC 

Questa istruzione serve per spostare verso sini¬ 
stra tutte le cifre di un numero binario presente 
nell’accumulatore. 

Sulla destra di tale numero entrerà un 1 o uno 0, 
che risulta parcheggiato in una particolare cella di 
memoria RAM chiamata CARRY, presente all’in¬ 
terno del microprocessore. 

Il valore del carry è 1 solo quando l’ultima opera¬ 



Fig.14 Se scrivete il programma con l’eti¬ 
chetta “nmijnt” riportato nel paragrafo RE¬ 
TI (vedi sopra), quando il piedino 5 del- 
l’NMI viene posto a livello logico 0, anche 
sull’uscita 5B ritroverete un livello logico 0 
ed il relè si disecciterà. 


zione eseguita ha un riporto, in altre parole quan¬ 
do il risultato è superiore a 255. 

Ad esempio, se il valore nell’accumulatore è 250, 
dopo aver eseguito l’istruzione: 

addi a,100 

il valore del carry è 1 . 

Tornando all’istruzione RLC, se all’interno dell’ac¬ 
cumulatore è presente il numero binario 
00000100 e nel carry è presente un 1, scrivendo 
l’istruzione: 

rie a 

ritroverete nell’accumulatore questo numero bina¬ 
rio: 

00001001 

Se nel carry fosse parcheggiato uno 0, nell’accu¬ 
mulatore ritrovereste questo numero binario: 

00001000 

La funzione RLC potrebbe risultarvi utile per ac¬ 
cendere in sequenza a ciclo continuo dei diodi 
led. Infatti il numero che perdete sulla sinistra en¬ 
tra nel carry per rientrare poi sulla destra. 

SLA 

Anche questa istruzione serve per spostare verso 
sinistra tutte le cifre di un numero binario pre¬ 
sente nell’accumulatore, con la sola differenza 
che, non utilizzando il carry, sulla destra entra sem¬ 
pre uno 0 ed il numero che fuoriesce a sinistra va 
perso. 

L’istruzione SLA può essere utile per ottenere una 

moltiplicazione per 2. 

Ad esempio, se nell’accumulatore è presente que¬ 
sto numero binario 

00010111 

che corrisponde al numero decimale 23, scriven¬ 
do: 

sla a 

nell’accumulatore troverete questo diverso nume¬ 
ro binario: 

00101110 

che corrisponde al numero decimale 46 (equiva¬ 
lente a 23 x 2). 

Il numero massimo che potete moltiplicare per 2 
è 127. 















STOP 

Questa istruzione serve per interrompere l’esecu¬ 
zione di un programma e per spegnere lo stadio o- 
scillatore del clock. 

E’ un’istruzione che si usa raramente. 

WAIT 

Questa istruzione serve per interrompere l’esecu¬ 
zione di un programma, con la sola differenza ri¬ 
spetto alla precedente, che non si spegne lo sta¬ 
dio oscillatore del clock. 

SUB 

Questa istruzione viene utilizzata per sottrarre dal 
numero presente nell’accumulatore il numero con¬ 
tenuto in una variabile. 

Se nell’accumulatore è presente il numero 183 e 
volete sottrargli il numero decimale 53, dovrete in¬ 
serire in una variabile, chiamata ad esempio pip- 
po, il numero 53 scrivendo questa istruzione: 


Idi 

a, 183 

; numero nell’accumulatore 

Idi 

pippo, 53 

; numero inserito nella variabile 

sub 

a, pippo 

; sottrai da a il valore di pippo 


Eseguita questa operazione nell’accumulatore a- 
vrete 183-53 = 130. 

SUBÌ 

Questa istruzione viene utilizzata per sottrarre dal 
numero presente nell’accumulatore un numero da 
voi inserito nella riga di questa istruzione. 

Se nell’accumulatore è presente il numero 183 e 
gli volete sottrarre il numero 53, dovrete scrivere 
l’istruzione in questo modo: 

Idi a,183 ; numero nell’accumulatore 

subi a,53 ; sottrai da a il numero 53 

Il risultato presente nell’accumulatore sarà dopo 
questa istruzione 130. 

Come per la precedente, anche con questa istru¬ 
zione non potete sottrarre un numero maggiore a 
quello presente nell’accumulatore. 

CONTINUA nel PROSSIMO NUMERO 


Sebbene con gli articoli e gli esempi pubblicati sul¬ 
le riviste N.172/173 e 174 siate già riusciti a pro¬ 
grammare e a cancellare senza difficoltà il mi¬ 
croprocessore ST6, questo non è ancora suffi¬ 
ciente per passare alla fase più propriamente pra¬ 
tica, iniziare cioè a scrivere dei programmi, perché 
occorre prima conoscere come vanno corretta- 
mente utilizzati: 

- la funzione watchdog 

- i piedini delle porte come ingressi 

- i piedini delle porte come uscite 

- la funzione interrupt 

- la funzione A/D converter 

- la funzione timer 


mente incolonnate ed in caso di necessità potrete 
controllarle meglio. 

Non è obbligatorio inserire l’ultimo blocco, quello del 
commento, ma se lo aggiungete dovete ricordarvi 
di farlo precedere sempre da un punto e virgola. 
Nei programmi che troverete di seguito ogni bloc¬ 
co è stato evidenziato da un rettangolo colorato 
in azzurro. 

Così se ad esempio in una riga di programma man¬ 
ca l’etichetta, troverete al suo posto un rettango¬ 
lo colorato senza alcuna scritta al suo interno. 
Questo per ricordarvi che per avere tutte le istru¬ 
zioni incolonnate dovete lasciare un carattere di ta¬ 
bulazione prima di scrivere il secondo blocco, quel¬ 
lo cioè dell’istruzione. 


IMPARARE a programmare 


NOTA IMPORTANTE 

Negli articoli precedenti (vedi riviste N.172/173 e 
174) vi abbiamo consigliato di scrivere tutte le 
istruzioni in minuscolo sottolineando nel frattem¬ 
po che non cambia assolutamente nulla se utiliz¬ 
zate la forma maiuscola. 

Abbiamo tuttavia notato che la tipografia quando 
trascrive questi testi in minuscolo compie più fre¬ 
quentemente errori tipografici; infatti confonde la 
lettera i con la lettera I e viceversa, la lettera r per 
la n, e spesso trascrive così vicino le due lettere r 
n da farle sembrare una m. 

Proprio per evitare questo tipo di errori da adesso 
in poi scriveremo le righe dei programmi un po’ in 
maiuscolo ed un po’ in minuscolo. 

Ripetiamo nuovamente che ogni riga di program¬ 
ma è composta da quattro blocchi chiamati Eti¬ 
chetta - Istruzione - Operando ; Commento (ve¬ 
di fig.1), che dovrete tenere distanziati gli uni dagli 
altri con un carattere di tabulazione. 

In questo modo avrete tutte le istruzioni perfetta- 


WATCHDOG 

Il watchdog è un contatore pilotato dalla frequen¬ 
za di clock del quarzo, che, iniziando dal numero 
che avete inserito nel registro wdog (è sempre be¬ 
ne inserire un numero alto, ad esempio 255), con¬ 
ta a rovescio fino ad arrivare a 0. 

Quando raggiunge lo 0, il watchdog resetta auto¬ 
maticamente il microprocessore, che in questo mo¬ 
do non potrà più proseguire con il programma che 
stava eseguendo. 

Il watchdog impedisce che eventuali disturbi pre¬ 
senti sulla tensione di rete dei 220 volt o generati 
da altri fonti, entrando involontariamente nel mi¬ 
croprocessore lo predispongano per eseguire fun¬ 
zioni non previste. 

Tanto per portare un esempio, supponiamo di aver 
programmato un ST6 per far eseguire ad un tor¬ 
nio automatico delle viti filettate lunghe 10 milli¬ 
metri. 

Può verificarsi il caso in cui un disturbo, entrando 
nel micro, lo predisponga per togliere la filettatura 


| ETICHETTA 


ISTRUZIONE | 


| OPERANDO | 

; 

| COMMENTO RIGA | 


Fig.1 Ogni riga di programma è composta da quattro blocchi che occorre tenere distan¬ 
ziati da uno “spazio”. Potrete anche non inserire l’ultimo blocco del COMMENTO, ma se 
lo utilizzate, dovrete farlo precedere da un “punto e virgola”. Se nella riga di un programma 
mancasse l’ETICHETTA, dovrete lasciare uno SPAZIO prima di scrivere l’ISTRUZIONE. 















Poiché ci siamo ripromessi di insegnarvi a programmare correttamen¬ 
te un ST6, è nostra intenzione spiegarvi in modo molto semplice e con 
numerosi esempi tutti i passi che bisogna compiere, per evitare che 
commettiate quei comuni ed involontari piccoli errori, che potrebbero 
impedire il regolare funzionamento del microprocessore. 


o per fare delle viti lunghe 10 centimetri. 

Per evitare che, in assenza di disturbi, il contato¬ 
re del watchdog possa raggiungere lo 0 e quindi 
resettare il microprocessore mentre sta eseguen¬ 
do le istruzioni del programma, dovrete sempre ri¬ 
cordarvi di inserire ogni 20 - 30 - 40 righe di pro¬ 
gramma questa scritta: 

LDI wdog,255 

Conviene inserire questa istruzione dopo un’eti¬ 
chetta che faccia ripetere alcune righe di pro¬ 
gramma diverse volte, perché è in questi casi che 
il contatore del watchdog può più facilmente sca¬ 
ricarsi, cioè raggiungere lo 0. 

Se ciò avviene, il microprocessore si resetta, in al¬ 
tre parole non può più proseguire con le successi¬ 
ve istruzioni ed il programma riparte dall’inizio. 
Molti programmatori principianti non trovando 
un’esauriente spiegazione e nemmeno nessun e- 
sempio su come utilizzarla, non inserivano que¬ 
sta istruzione, e quando il programma si blocca¬ 
va perché il watchdog arrivava a 0, non sapen¬ 
do trovare un’altra spiegazione, cambiavano l’ST6 


ritenendolo difettoso oppure cercavano nel pro¬ 
gramma un errore, che in realtà non esisteva. 

A chi ci ha interpellato per queste anomalie ab¬ 
biamo chiesto se vicino ad un’etichetta ripeti o ad 
una funzione che il programma eseguiva diverse 
volte era stata riportata la riga LDI wdog,255, e 
quasi sempre abbiamo ricevuto una risposta ne¬ 
gativa. 

Dopo aver spiegato che il watchdog si può para¬ 
gonare ad una pila ricaricabile e, come tale, ogni 
tanto occorre ricaricarla per evitare che arrivi a 0 
volt, tutti hanno capito l’importanza di questa 
funzione e dopo averla inserita nel loro program¬ 
ma gli inconvenienti lamentati sono spariti. 

Negli esempi che trovate in questo articolo trove¬ 
rete spesso questa istruzione: 

ripeti LDI wdog,255 ; carica il watchdog 

; programma 
JP ripeti ; salta a ripeti 

che in pratica serve a ricaricare questa “pila” sul 
numero massimo che possiamo inserire, cioè 255. 






TABELLA N.1 per ST62/E10 - ST62/T10 - ST62/E20 - ST62/T20 


porta 

AO 

Al 

A2 

A3 

BO 

B1 

B2 

B3 

B4 

B5 

B6 

B7 

piedino 

19 

18 

17 

16 

15 

14 

13 

12 

11 

10 

9 

8 



AO 

Al 

A2 

A3 


BO 

B1 

B2 

B3 

B4 

B5 

B6 

B7 



ST 62 E IO 
ST 62 T IO 
ST 62 E 20 
ST 62 T 20 


Fig.2 Airinterno dei micro- 
processori ST62 della se¬ 
rie 10-20 sono presenti 
due PORTE chiamate A-B. 
Nella porta A troviamo so¬ 
lo quattro piedini Ingres- 
si/Uscita siglati A0-A1-A2- 
A3, mentre nella porta B 
troviamo otto piedini si¬ 
glati da BO a B7. 

Nella Tabella sopra ripor¬ 
tata abbiamo indicato a 
quale piedino dell’ST6 cor¬ 
rispondono i piedini di 
queste due PORTE. 


TABELLA N.2 per ST62/E15 - ST62/T15 - ST62/E25 - ST62/T25 


porta 

A0 

Al 

A2 

A3 

A4 

A5 

A6 

A7 

B0 

B1 

B2 

B3 

B4 

B5 

B6 

B7 

C4 

C5 

C6 

C7 

piedino 

27 

26 

25 

24 

23 

22 

21 

20 

19 

18 

17 

16 

15 

14 

13 

12 

9 

8 

7 

6 



AO 

Al 

A2 

A3 

A4 

A5 

A6 

A7 


BO 

B1 

B2 

B3 

B4 

B5 

B6 

B7 

C4 

C5 

C6 

C7 



ST 62 E 15 
ST 62 T 15 
ST 62 E 25 
ST 62 T 25 


Fig.3 AN’interno dei micro- 
processori ST62 della se¬ 
rie 15-25 sono presenti tre 
PORTE chiamate A-B-C. 
Nelle due porte A-B sono 
presenti otto piedini In- 
gressi/Uscita siglati da AO 
a A7 e da BO a B7, mentre 
nella porta C troviamo so¬ 
lo quattro piedini siglati 
C4-C5-C6-C7. 

Nella Tabella sopra ripor¬ 
tata abbiamo indicato a 
quale piedino dell’ST6 cor¬ 
rispondono i piedini di 
queste tre PORTE. 






































































LE PORTE sui piedini 
del MICROPROCESSORE 


All’interno di tutti i microprocessori ST6 sono pre¬ 
senti due oppure tre porte siglate A-B-C i cui ter¬ 
minali, contraddistinti dalle sigle AO - Al - A2 ecc. 
e BO - B1 - B2 ecc., fanno capo ai piedini del mi¬ 
croprocessore (vedi figg.2-3). 

Nelle Tabelle N.1 e N.2 riportiamo i numeri dei pie¬ 
dini a cui sono collegati i terminali delle porte pre¬ 
senti nei diversi integrati ST6. 

Conoscere a quale piedino risultano collegati i ter¬ 
minali di queste porte è molto importante, perché 
nella riga del programma non viene mai indicato il 
numero del piedino, ma la sola sigla della porta, 
cioè AO - A2 - A3 o B5 - B6 - B7 ecc. 

COME SETTARE LE PORTE 

Per settare il piedino prescelto come ingresso 
senza pull-up - ingresso con interrupt - ingres¬ 
so analogico - ingresso pull-up oppure come u- 
scita open collector - uscita push-pull, dobbia¬ 
mo inserire nei registri pdir - popt - port degli 0 o 
degli 1, disponendoli come abbiamo riportato nella 
Tabella N.3. 



Fig.4 Inserendo nei tre registri PDIR - POPT 
- PORT degli 0 o degli 1 (vedi Tabella N.3), 
noi possiamo predisporre il piedino di una 
qualsiasi Porta a funzionare come Ingres¬ 
so oppure come Uscita. 


Esempio: Ammesso di voler predisporre tutti i pie¬ 
dini della porta A come ingressi tipo pull-up, do¬ 
vremmo necessariamente scrivere queste tre righe: 

LDI pdir_a,00000000B 
LDI popt_a,00000000B 
LDI port_a,00000000B 

Se volessimo invece predisporre tutti i piedini del¬ 
la porta A come uscita in push-pull dovremmo 
necessariamente scrivere queste tre righe. 

LDI pdir_a,11111111B 
LDI popt_a,11111111B 
LDI port_a,00000000B 


Ricordatevi che dopo il nome dei tre registri, pdir 
- popt - port, bisogna sempre indicare il tipo di por¬ 
ta che si vuole utilizzare scrivendo: 

_a se la porta è la A 
_b se la porta è la B 
_c se la porta è la C 

Non scrivete -a, in altre parole non utilizzate il se¬ 
gno della sottrazione, ma sempre il segno del sot¬ 
tolineato, cioè _a. 

La lettera B, posta dopo l’ultima cifra di destra di 
ogni riga, serve ad indicare che si tratta di un nu¬ 
mero binario. 


TABELLA N.3 per predisporre gli ingressi e le uscite 


z 

» 

c n 

1 INGRESSI 1 

I USCITE 

’5> 

(D 

OC 

con 

pull-up 

senza 

pull-up 

con 

interrupt 

per segnali 
analogici 

open 

collector 

uscita 

push-pull 

pdir 

0 

0 

0 

0 

1 

1 

popt 

0 

0 

1 

1 

0 

1 

port 

0 

1 

0 

1 

0 

0 


Fig.5 Per predisporre il piedino di una Porta a funzione come Ingresso oppure come U- 
scita, bisogna scrivere nei tre registri PDIR - POPT - PORT gli 0 o gli 1 nell’ordine ripor¬ 
tato in questa Tabella. Nell’articolo trovate molti esempi su come settare queste Porte. 






































NOTA IMPORTANTE: Non tutti i piedini delle por¬ 
te si possono settare come ingresso per segnali 
analogici, quindi per evitare errori ricordatevi che 
di tutti i microprocessori riportati sia nella Tabella 
N.1 sia nella Tabella N.2, non potrete mai utilizza¬ 
re come ingressi analogici i piedini AO - Al - A2 
-A3. 

Queste porte potranno invece essere settate per 
tutti gli altri tipi di ingresso, cioè con pull-up - sen¬ 
za pull-up - con interrupt. 

Al contrario tutti i piedini di tutte le porte possono 
essere settati come uscite, tenendo presente che 
l’uscita più comunemente utilizzata è il push-pull, 
che si ottiene ponendo a 1-1-0 i tre registri pdir, 
popt e port. 


Ogni terminale di queste porte viene definito da 
uno degli otto numeri posti dopo la virgola, ricor¬ 
dando che il terminale 7 è la prima cifra a sinistra 
ed il terminale 0 è l’ultima cifra a destra, come qui 
sotto riportato: 

TABELLA N.4 


cifra 

1° 

m 

il 

A5 

EH 

A4 

E I 

A3 

EH 

A2 

EH 

Al 

m 

A0 

piedino 

A7 

A6 

piedino 

B7 

B6 

B5 

B4 

B3 

B2 

B1 

B0 

piedino 

C7 

C6 

C5 

C4 






Quindi se volessimo caricare un 1 nel registro pdir 
di A7 dovremmo scrivere: 


Per concludere facciamo presente che l’ingresso 
più comunemente utilizzato è quello con pull-up 
che si ottiene ponendo a 0-0-0 i tre registri pdir, 
popt e port. 

E’ inoltre sempre consigliabile settare come in¬ 
gressi tutti i piedini che non vengono usati, perché 
in questo modo non si corre il rischio di provocare 
involontariamente dei cortocircuiti che potrebbe¬ 
ro mettere fuori uso il microprocessore. 

Infatti se un piedino che non viene utilizzato viene 
settato come uscita e poi viene collegato invo¬ 
lontariamente a massa, anche tramite una resi¬ 
stenza di basso valore, può capitare che per un er¬ 
rore nel programma questo piedino cambi il suo 
stato logico da 0 a 1, ed in questo caso in uscita 
si potrebbe ritrovare una tensione positiva di 5 volt 
che potrebbe provocare dei cortocircuiti. 

Per questo motivo, come noterete dagli esempi, 
tutti i piedini delle porte A - B - C che non ven¬ 
gono utilizzati li abbiamo settati come ingressi in 
pull-up. 


LDI pdir_a,10000000B 

mentre se volessimo caricare un 1 nel registro 
pdir di A4 dovremmo scrivere: 

LDI pdir_a,00010000B 

ed ancora se volessimo caricare un 1 nel registro 
pdir di AO dovremmo scrivere: 

LDI pdir_a,00000001B 

Per completare il settaggio di ogni porta si devo¬ 
no aggiungere le altre due righe di programma, do¬ 
ve compaiono i registri popt e port, mettendo de¬ 
gli 0 o degli 1 come riportato nella Tabella N.3. 

Ammesso che si voglia settare il piedino 5 della 
porta B come uscita in push-pull si dovrà scrive¬ 
re: 


Posizione dei PIEDINI 
nel NUMERO BINARIO 

Per poter predisporre i piedini delle porte come in¬ 
gressi o come uscite si utilizza un numero bina¬ 
rio composto da otto cifre. 

Molti tra voi si staranno chiedendo come si fa a ca¬ 
pire qual è il piedino A0 - Al - A2 ecc. oppure B0 
- B1 - B2 ecc., in quanto anche se abbiamo indi¬ 
cato il tipo di porta con _a, con _b o con _c, non 
abbiamo mai precisato il suo terminale 0-1-2-3-4- 
5-6-7. 

Inoltre non abbiamo ancora specificato come ci si 
deve comportare con i microprocessori della Ta¬ 
bella N.1, dove la porta A ha solo quattro piedini 
siglati A0 - Al - A2 - A3 o con quelli della Tabel¬ 
la N.2, dove la porta C ha invece quattro piedini 
siglati C4 - C5 - C6 - C7. 


LDI 

popt_b,00100000B 

LDI 

port_b,00000000B 


Infatti la sequenza per settare un piedino in usci¬ 
ta push-pull è 1-1-0, e, come abbiamo riportato 
nella Tabella N.4, il piedino B5 è la terza cifra a 
partire da sinistra. 

Come abbiamo già avuto modo di dire, tutti i pie¬ 
dini delle porte A - B - C che non vengono utiliz¬ 
zati devono comunque essere settati come in¬ 
gressi in pull-up (0 - 0 - 0). 

Nei microprocessori che hanno solo quattro piedi¬ 
ni per la porta A (A0 - Al - A2 - A3), si devono 
comunque riportare sempre tutte le otto cifre del 

numero binario. 

Quindi se volessimo predisporre come uscite pu- 















sh-pull i piedini della porta A di un ST62E10, do¬ 
vremmo scrivere: 


LDI pdir_a,00001111B 
LDI popt_a,00001111B 
LDI port_a,00000000B 


Allo stesso modo, se volessimo predisporre come 
uscite push-pull tutti i quattro piedini dei micro- 
processori che hanno anche la porta C (C4 - C5 - 
C6 - C7) dovremmo scrivere: 


LDI pdir_c,11110000B 
LDI popt_c,11110000B 
LDI port_c,00000000B 


Ogni piedino di ogni porta può essere singolar¬ 
mente settato come ingresso o come uscita e 
persino in maniera differente. 

Ad esempio, possiamo settare il piedino B1 della 
porta B come uscita push-pull, il piedino B2 co¬ 
me ingresso pull-up, il piedino B3 come ingres¬ 
so analogico ed il piedino B4 come uscita open 
collector. 


ESEMPI di SETTAGGIO piedini 

Esempio N.1 = Disponendo di un ST6 del tipo ri¬ 
portato nella Tabella N.1, ad esempio un ST62E10, 
vorremmo programmare i piedini A0 - Al come in¬ 
gressi senza pull-up ed i piedini B4 - B5 - B6 - 
B7 come uscite in push-pull. 

Soluzione: Per scrivere queste istruzioni esami¬ 
niamo prima di tutto la Tabella N.3, per sapere qual 
è la cifra, se 0 o 1, che dobbiamo mettere nei tre 
registri pdir - popt - port. 

Sapendo che per ogni riga che definisce il settag¬ 
gio dei piedini dobbiamo sempre mettere 8 cifre e 
che il piedino 7 è definito dalla prima cifra a sini¬ 
stra e lo 0 dall’ultima cifra a destra, possiamo scri¬ 
vere le nostre istruzioni: 


LDI 

pdir_a,00000000B 

LDI 

popt_a,00000000B 

LDI 

port a,00000011B 


LDI 

pdir_b,11110000B 

LDI 

popt_b,11110000B 

LDI 

port_b,00000000B 


legenda: 

LDI = significa carica sul registro. 

pdir - popt - port = sono i tre registri necessari per 
settare una porta. 

_a e _b = sono le porte A e B ed il numero che 
segue dopo la virgola indica quale degli otto pie¬ 
dini, 7-6-5-4-3-2-1-0, vogliamo settare come in¬ 
gresso o come uscita. 

B = questa lettera posta sull’estrema destra indica 

che il numero a otto cifre è un Binario. 


Esempio N.2 = Disponendo di un ST6 del tipo ri¬ 
portato nella Tabella N.2, ad esempio un ST62E15, 
vorremmo programmare tutti i piedini delle porte 
A-B-C come ingressi pull-up. 

Soluzione: Controlliamo nella Tabella N.3 se dob¬ 
biamo mettere uno 0 o un 1 nei tre registri pdir - 
popt - port per poterli settare come ingressi pull- 
up, quindi poiché in tutti va inserito uno 0 scrivia¬ 
mo: 


LDI pd i r_a,00000000B 
LDI popt_a,00000000B 
LDI port_a,00000000B 

LDI pd i r_b,00000000B 
LDI popt_b,00000000B 
LDI port_b,00000000B 

LDI pd i r_c,00000000B 
LDI popt_c,00000000B 
LDI port_c,00000000B 

Come avrete notato, anche sulla porta C abbiamo 
messo tutti 0 sebbene questa abbia solo quattro 
piedini siglati C4 - C5 - C6 - C7. 


Esempio N.3 = Disponendo di un ST6 del tipo ri¬ 
portato nella Tabella N.2 vorremmo programmare 
il piedino B2 come ingresso pull-up, il piedino B1 
come ingresso analogico ed il piedino C7 come 
uscita push-pull. 

Soluzione: Controlliamo innanzitutto nella Tabella 
N.3 come vanno settati i tre registri pdir - popt - 
port per avere un ingresso pull-up, un ingresso 
analogico ed una uscita push-pull, quindi sa¬ 
pendo che per ogni riga di programma dobbiamo 


sempre mettere 8 cifre e che il piedino 7 è defini¬ 
to dalla prima cifra a sinistra e lo 0 dall’ultima ci¬ 
fra a destra, scriviamo: 

LDI pdir_a,00000000B 
LDI popt_a,00000000B 
LDI port_a,00000000B 

LDI pdir_b,00000000B 
LDI popt_b,00000010B 
LDI port_b,0000001OB 

LDI pdir_c,10000000B 
LDI popt_c,10000000B 
LDI port_c,00000000B 

Come indicato dalla Tabella N.3, nei tre registri re¬ 
lativi alla porta B abbiamo messo 0-0-0 per il pie¬ 
dino B2 e 0-1-1 per il piedino B1, mentre nelle tre 
righe relative alla porta C, per il piedino C7 abbia¬ 
mo posto 1-1-0. 

Qualcuno si starà già chiedendo in quale applica¬ 
zione pratica possiamo utilizzare un piedino setta¬ 
to come ingresso. Anche se in seguito troverete 
alcuni esempi su questo argomento, possiamo an¬ 
ticiparvi subito che potete usarlo per vedere se 
sull’Ingresso entra una tensione positiva oppure 
per stabilire se questa cambia di stato logico da 0 
ale viceversa, o ancora per convertire una ten¬ 
sione analogica in una digitale ecc. 


Esempio N.4 = Abbiamo realizzato lo schema di 
fig.6 da utilizzare per un antifurto, quindi vorremmo 
che si eccitasse un relè ogni volta che l’interrutto¬ 
re viene pigiato. 

Soluzione: La prima operazione da compiere è 
quella di settare il piedino della porta che voglia¬ 
mo utilizzare come ingresso ed il piedino della por¬ 
ta che vogliamo utilizzare come uscita. 

Come ingresso abbiamo deciso di scegliere il pie¬ 
dino Al e come uscita il piedino A2. 



Dalla Tabella N.3 controlliamo come settare i re¬ 
gistri pdir - popt - porta per far diventare questi 
piedini ingressi o uscite, dopodiché possiamo 
scrivere tutte le righe del programma indicato a fi¬ 
ne pagina. 

Nella riga ripeti abbiamo ricaricato il watchdog, 
poi con l’istruzione JRS abbiamo detto al pro¬ 
gramma di saltare all’etichetta eccita solo quando 
sul piedino Al riscontra una tensione di 5 volt. 

Se non riscontra questa condizione, il micropro¬ 
cessore passa ad eseguire la riga JRR e da qui 
salta all’etichetta spegni, che diseccita il relè se 
prima risultava eccitato, o lo lascia diseccitato se 
si trova già in questa condizione. 



LDI 

LDI 

LDI 

pdir_a,00000100B 
popt_a,00000100B 
port_a,00000000B 

con queste tre righe abbiamo settato la porta Al come 

ingresso e la porta A2 come uscita 

ripeti 

LDI 

wdog,255 

ricarica il watchdog 


JRS 

1,port_a,eccita 

se in Al ci sono 5 Volt salta a eccita 


JRR 

1,port_a,spegni 

se in Al ci sono 0 Volt salta a spegni 

eccita 

SET 

2,port_a 

setta a 5 volt l’uscita di A2 


JP 

ripeti 

salta all’etichetta ripeti 

spegni 

RES 

2,port_a 

setta a 0 volt l’uscita di A2 


JP 

ripeti 

salta all’etichetta ripeti 

























Esempio N.5 = Abbiamo realizzato lo schema di 
fig.7 e vorremmo che, quando l’interruttore corto¬ 
circuita verso massa il piedino d’ingresso Al, si 
eccitasse il relè collegato sull’uscita A2. 
Soluzione: La prima operazione da compiere è 


quella di settare il piedino Al come ingresso ed 
il piedino A2 come uscita. 

In questo caso, dovendo ottenere una funzione op¬ 
posta a quella dell’esempio N.4, dovremo scrive¬ 
re il programma come indicato di seguito: 



LDI 

LDI 

LDI 

pdir_a,00000100B 
popt_a,00000100B 
port_a,00000000B 

; con queste tre righe abbiamo settato la porta Al come 

; ingresso e la porta A2 come uscita 

J 

ripeti 

LDI 

wdog,255 

; ricarica il watchdog 


JRR 

1 ,port_a, eccita 

; se in Al ci sono 0 Volt salta a eccita 


JRS 

1,port_a,spegni 

; se in Al ci sono 5 Volt salta a spegni 

eccita 

SET 

2,port_a 

; setta a 5 volt l’uscita di A2 


JP 

ripeti 

; salta all’etichetta ripeti 

spegni 

RES 

2,port_a 

; setta a 0 volt l’uscita di A2 


JP 

ripeti 

; salta all’etichetta ripeti 


Esempio N.6 = Ammettiamo di voler predisporre 
tutti i piedini della porta A e della porta B come u- 

scite in push-pull. 


Soluzione: Per ottenere questa condizione dob¬ 
biamo scrivere solo 1 per i due registri pdir - popt 
e solo 0 per il terzo registro port (vedi Tabella N.3). 


LDI 

pdir_a,11111111B 

LDI 

popt_a,11111111B 

LDI 

port a,00000000B 


LDI 

pdir_b,11111111B 

LDI 

popt_b,11111111B 

LDI 

port_b,00000000B 


Se la porta A disponesse di solo 4 piedini (vedi 
microprocessori della Tabella N.1) dovremmo scri¬ 
vere 1 solo sui piedini delle porte utilizzate. 

Esempio N.7 = Supponiamo di voler predisporre i 
piedini AO - Al - A2 - A3 e BO - B1 come ingres¬ 
si pull-up e i piedini A4 - A5 - A6 - A7 e B2 - B3 
- B4 - B5 - B6 - B7 come uscite push-pull. 

In questo caso dovremo scrivere: 


LDI 

pdir_a,11110000B 

LDI 

popt_a,11110000B 

LDI 

port_a,00000000B 

LDI 

pdir_b,11111100B 

LDI 

popt_b,11111100B 

LDI 

port_b,00000000B 


Esempio N.8 = Abbiamo un microprocessore del 
tipo riportato nella Tabella N.2, con a disposizione 
le tre porte A-B-C, e vorremmo predisporre tutte i 
piedini della porta A-B come ingressi pull-up e 


quelli della porta C come uscite push-pull. 
In questo caso dovremo scrivere: 


LDI 

pdir_a,00000000B 

LDI 

popt_a,00000000B 

LDI 

port_a,00000000B 

LDI 

pd i r_b,00000000B 

LDI 

popt_b,00000000B 

LDI 

port_b,00000000B 


LDI 

pdir_c,11110000B 

LDI 

popt_c,11110000B 

LDI 

port_c,00000000B 


INTERRUPT 

L’Interrupt serve per “interrompere” momentanea¬ 
mente l’esecuzione delle istruzioni principali affin¬ 
ché il microprocessore possa eseguire altre istru¬ 
zioni, che si trovano inserite tra una delle cinque e- 
tichette qui sotto riportate e la scritta reti. 

adjnt ; etichetta 

; programma da eseguire 
reti ; fine interrupt 

timjnt ; etichetta 

; programma da eseguire 
reti ; fine interrupt 

BCJnt ; etichetta 

; programma da eseguire 
reti ; fine interrupt 






AJnt ; etichetta 

; programma da eseguire 
reti ; fine interrupt 

nmijnt ; etichetta 

; programma da eseguire 
reti ; fine interrupt 

Nota: la funzione di interrupt viene abilitata ed 
eseguita dal microprocessore solo se nel pro¬ 
gramma è stata scritta la seguente istruzione: 

SET 4,ior 

Dopo aver scritto le righe di programma da ese¬ 
guire con la funzione interrupt è necessario com¬ 
pletarle con la scritta reti, perché quando il micro- 
processore arriva ad eseguire l’istruzione reti ri¬ 
torna al programma principale nel punto in cui era 
stato momentaneamente interrotto. 

L’interrupt viene utilizzato per far eseguire al mi¬ 
croprocessore un’istruzione che in quel momento 
è più importante di quella che stava eseguendo. 
Ad esempio, se avessimo programmato un micro- 
processore per aprire e chiudere il cancello scor¬ 
revole del nostro giardino, dovremmo utilizzare la 
funzione interrupt applicata alla fotocellula per fa¬ 
re in modo che in fase di chiusura se un bambino 
o il nostro cane attraversa improvvisamente la fo¬ 
tocellula, il cancello si blocchi. 


Etichetta ad int 


Questa etichetta serve per riconoscere quando il 
convertitore A/D ha terminato la conversione. Nor¬ 
malmente non si usa mai perché in sua sostitu¬ 


zione si preferisce scrivere questa riga di pro¬ 
gramma. 

attendi JRR 6, adcr, attendi 


Etichetta tim int 


Questa etichetta viene utilizzata nelle funzioni ti¬ 
mer. In pratica quando il registro ter (vedi para¬ 
grafo Timer) arriva a 0, il microprocessore esegue 
tutte le istruzioni che sono state scritte tra timjnt 
e reti. 


Etichetta BC int 


Questa etichetta viene utilizzata per fare eseguire 
tutte le istruzioni che abbiamo scritto tra BCJnt e 
reti quando su uno dei piedini da noi scelto delle 
porte B o C la tensione cambia di stato, in altre pa¬ 
role quando passa dal livello logico 0 al livello lo¬ 
gico 1 (fronte di salita) o quando passa dal livel¬ 
lo logico 1 al livello logico 0 (fronte di discesa). 

Nota: per la funzione ingresso con interrupt pos¬ 
siamo abilitare un solo piedino di una delle due 
porte B o C. 

Esempio N.9 = Supponiamo di voler settare il 
piedino B2 come ingresso con interrupt che in¬ 
tervenga sul fronte di salita e tutti gli altri pie¬ 
dini della porta B come ingresso in pull-up. Co¬ 
me prima operazione controlliamo nella Tabel¬ 
la N.3 come vanno settati i registri pdir - popt 
- port per l’ingresso con interrupt, dopodiché 
possiamo scrivere il programma indicato 
"Esempio n.9“. 


PROGRAMMA per Esempio n.9 


LDI pdir_b,00000000B 

LDI popt_b,00000100B 

LDI port_b,00000000B 

abbiamo settato il piedino B2 come ingresso interrupt 
e tutti gli altri come ingressi pull-up 

SET 4,ior 

serve per abilitare l’interrupt 

SET 5,ior 

serve per sentire il fronte di salita 

BCJnt 

etichetta d’inizio interrupt 


istruzioni da eseguire con l’interrupt 

RETI 

istruzione fine interrupt 


PROGRAMMA per Esempio n.10 

LDI pdirJ},00000000B 

LDI popt_b,10000000B 

LDI port_b,00000000B 

abbiamo settato il piedino B7 come ingresso interrupt 
e tutti gli altri come ingressi pull-up 

SET 4,ior 

serve per abilitare l’interrupt 

RES 5,ior 

serve per sentire il fronte di discesa 

BCJnt 

etichetta d’inizio dell’interrupt 


istruzioni da eseguire con l’interrupt 

RETI 

istruzione fine interrupt 












Esempio N.10 = Supponiamo di voler settare il 
piedino B7 come ingresso con interrupt che in¬ 
tervenga sul fronte di discesa e tutti gli altri pie¬ 
dini della porta B come ingresso in pull-up. Come 
prima operazione controlliamo nella Tabella N.3 
come vanno settati i registri pdir - popt - port per 
l’ingresso con interrupt, dopodiché possiamo scri¬ 
vere il programma indicato "Esempio n.10“. 


Etichetta A int 


Questa etichetta viene utilizzata per fare eseguire 
tutte le istruzioni che abbiamo scritto tra AJnt e 
reti quando sul piedino della porta A da noi scelto 
la tensione passa dal livello logico 1 al livello lo¬ 
gico 0 (fronte di discesa). 


tutti gli ST6) la tensione passa dal livello logico 1 
al livello logico 0 (fronte di discesa). Poiché que¬ 
sto piedino è sempre abilitato, non è necessario 
scrivere nel programma l’istruzione: 

SET 4,ior 

Esempio N.12 = Vogliamo che pigiando il pulsan¬ 
te PI (vedi fig.8) si accendano i diodi led applica¬ 
ti sui piedini AO - Al - A2 - A3. 

Come prima operazione settiamo i piedini AO - Al 
- A2 - A3 come uscite push-pull prelevando dal¬ 
la Tabella N.3 i dati da inserire nelle righe pdir - 
popt - port e a questo punto possiamo scrivere il 
programma indicato "Esempio n.12“. 


Nota: per la funzione ingresso con interrupt pos¬ 
siamo abilitare un solo piedino della porta A. 

Esempio N.11 = Ammettiamo di voler settare il 
piedino A5 come ingresso con interrupt che in¬ 
tervenga quando il livello logico 1 cambia a livello 
logico 0. Come prima operazione controlliamo nel¬ 
la Tabella N.3 come dobbiamo settare i registri 
pdir - popt - port per l’ingresso con interrupt, do¬ 
podiché possiamo scrivere il programma indicato 
"Esempio n.11“. 


Etichetta nmi int 


Questa etichetta viene utilizzata per fare eseguire 
tutte le istruzioni che abbiamo scritto tra nmijnt e 
reti quando sul piedino siglato NMI (piedino 5 di 


NOTA IMPORTANTE: se nelle righe del program¬ 
ma dell’interrupt fossero presenti delle istruzioni 
che utilizzano l’accumulatore A, ad esempio: 


ADDI 

a’iO 

3 . .w 

; somma ad A il numero 10 

LDI 

a,10 

; metti in A il numero 10 


bisognerà inserire in una variabile, che potremo 
chiamare salva, il valore dell’accumulatore A su¬ 
bito dopo l’etichetta dell’interrupt e, prima di ter¬ 
minare con l’istruzione RETI, lo dovremo reinseri¬ 
re nell’accumulatore A. 

In questo modo quando il microprocessore tornerà 
ad eseguire il programma principale, nell’accumu¬ 
latore si avrà lo stesso valore che c’era prima 
dell’interrupt. 


PROGRAMMA per Esempio n.11 


LDI 

pdir_a,00000000B 

; abbiamo settato il piedino A5 come ingresso interrupt 

LDI 

popt_a,00100000B 

; e tutti gli altri come ingressi pull-up 

LDI 

port_a,00000000B 

3 

SET 

4,ior 

; serve per abilitare l’interrupt 

AJnt 


; etichetta d’inizio dell’interrupt 

; istruzioni da eseguire con l’interrupt 

RETI 


; istruzione fine interrupt 


PROGRAMMA per Esempio n.12 


LDI 

LDI 

LDI 

pdir_a,00001111B 
popt_a,00001111B 
port_a,00000000B 

con queste tre righe abbiamo settato come uscite 
push-pull i piedini A0 - Al - A2 - A3 


etichetta d’inizio dell’interrupt 

SET 

0,port_a 

accendi il led sul piedino A0 

SET 

1,port_a 

accendi il led sul piedino Al 

SET 

2,port_a 

accendi il led sul piedino A2 

SET 

3,port a 

accendi il led sul piedino A3 

RETI 

istruzione fine interrupt 






gresso analogico si può calcolare con questa for¬ 
mula: 



AO 

Al 

A2 

A3 


—VWW-0—1 
—VWW-@H' 

“I 1 

1 


Fig.8 Affinché, pigiando il pulsante posto 
sul piedino “NMI”, si accendano tutti i led 
applicati sui piedini A0-A1-A2-A3, potrete u- 
tilizzare il programma riportato nell’Esem¬ 
pio N.12 o quello dell’Esempio N.13. 


numero decimale = (volt x 255) : 5 

Pertanto se applichiamo sul piedino d’ingresso 
una tensione di 4 volt otteniamo un numero de¬ 
cimale di: 

(4 x 255) : 5 = 204 

Ricordatevi che l’A/D converter fornisce in uscita 
soltanto dei numeri interi quindi se nel risultato so¬ 
no presenti dei decimali, questi vengono arroton¬ 
dati al numero intero più prossimo. 

Ad esempio, se la tensione di 4 volt dovesse scen¬ 
dere a 3,98 volt, sull’uscita non otterremmo: 


Esempio N.13 = Nell’esempio N.12 abbiamo ri¬ 
portato un programma che accendeva contempo¬ 
raneamente quattro diodi led pigiando il pulsante 
collegato sul piedino NMI (vedi fig.8). Usando l’ac¬ 
cumulatore A si ottiene lo stesso risultato, ma bi¬ 
sogna modificare il programma come indicato 
nell "Esempio n.13“. 


(3,98 x 255) : 5 = 202,98 

ma il numero più prossimo, cioè 203. 

Se la tensione di 4 volt dovesse salire a 4,04 volt, 
sull’uscita non otterremmo: 

(4,04 x 255) : 5 = 206,04 


A/D CONVERTER 


ma il numero più prossimo, cioè 206. 


All’interno di ogni microprocessore ST6 è presen¬ 
te un A/D converter, cioè un circuito in grado di 
convertire una tensione analogica compresa tra 0 

e 5 volt in un numero decimale compreso tra 0 e 
255. 

Per ottenere questa condizione occorre settare il 
piedino della porta in cui viene applicata questa 
tensione come ingresso analogico. 

Ricordatevi che in tutti i microprocessori della se¬ 
rie ST6 (vedi Tabelle N.1 - N.2) non possono es¬ 
sere mai utilizzati come ingressi per segnali ana¬ 
logici i piedini A0 - Al - A2 - A3. 

La massima tensione che si può applicare su que¬ 
sti ingressi non deve mai superare i 5 volt positivi. 
Il valore numerico che otteniamo applicando una 
tensione al piedino che abbiamo settato come in- 


Anche con l’arrotondamento del numero si ottiene 
sempre un’elevata precisione in quanto la diffe¬ 
renza risulta di sole poche decine di millivolt. 

Ad esempio, prendendo sempre la tensione di 4 
volt, per ogni variazione di 0,01 volt otterremo que¬ 
sti numeri decimali: 


3.96 volt = 202 

3.97 volt = 202 

3.98 volt = 203 

3.99 volt = 203 
4,00 volt = 204 
4,01 volt = 205 
4,02 volt = 205 
4,03 volt = 206 
4,04 volt = 206 


PROGRAMMA per Esempio n.13 


LDI 

LDI 

LDI 

pdir_a,00001111B 
popt_a,00001111B 
port_a,00000000B 

con queste tre righe abbiamo settato come uscite 
push-pull i piedini A0 - Al - A2 - A3 



etichetta d’inizio dell’interrupt 

LD 

salva,a 

copia nella variabile salva il valore di A 

LDI 

a,00001111B 

carica in A il numero binario 00001111 

LD 

port_a,a 

copia il valore A nel registro della porta a 

LD 

a,salva 

copia nell’accumulatore A il valore di salva 

RETI 

istruzione fine interrupt 















Conoscendo il numero decimale è possibile cal¬ 
colare il valore della tensione in volt utilizzando 
questa formula: 

volt = (decimale x 5) : 255 

Quindi il numero decimale 203 corrisponde ad un 
valore di tensione pari a: 

(203 x 5) : 255 = 3,98 volt 

con una differenza di 0,01 volt in più o in meno. 
Come abbiamo già detto, un ingresso settato per 
segnali analogici può servire soltanto per misu¬ 
rare delle tensioni continue che non superino i 5 

volt. 

Se la tensione risultasse maggiore, occorrerà ri¬ 
durla con dei partitori resistivi, come in pratica ac¬ 
cade in tutti i tester analogici che, pur disponen¬ 
do di uno strumento da 1 volt fondo scala, pos¬ 
sono misurare tensioni anche di 250 - 300 volt. 

E’ inoltre possibile misurare delle tensioni alter¬ 
nate, se si provvede prima a raddrizzarle. 

Un ingresso analogico può servire per misurare 
delle temperature, delle variazioni di luce, degli 
ohm oppure la reattanza dei condensatori o delle 
impedenze, ed anche la corrente assorbita da un 
circuito o la potenza di un amplificatore. 

IMPORTANTE: Poiché all’interno dei microproces¬ 
sori ST6 è presente un solo A/D converter, solo 
un piedino può essere adibito a questa funzione. 
Se per errore vengono settati come ingressi per 
segnali analogici due piedini, questi verranno po¬ 
sti in cortocircuito ed in questo modo verrà dan¬ 
neggiato il microprocessore. 


Esempio N.14 = Vogliamo realizzare un circuito 
che accenda un diodo led quando la tensione ap¬ 
plicata sul piedino prescelto supera i 3 volt. Per 
l’ingresso si potrebbe decidere di utilizzare il pie¬ 
dino B1 e come uscita il piedino A0 (vedi fig.9). 



Fig.9 Per accendere il diodo led applicato 
sul piedino A0 quando la tensione sul pie¬ 
dino B1 supera i 3 Volt, dovrete scrivere il 
programma posto a fine pagina. Leggere at¬ 
tentamente la soluzione dell’Esempio N.14. 


Come si deve scrivere il programma perché il mi- 
cro esegua questa funzione? 

Soluzione: Dalla Tabella N.3 controlliamo come 
dobbiamo settare i registri pdir - popt - port per 
predisporre B1 come ingresso analogico e A0 co¬ 
me uscita in push-pull. 

Successivamente calcoliamo il numero decimale 
di 3 volt che risulta: 

(3 x 255) : 5 = 153 

A questo punto possiamo scrivere il nostro pro¬ 
gramma. 


PROGRAMMA per Esempio n.14 

LDI pdir_a,00000001B 

LDI popta,00000001B 

LDI port a,00000000B 

in queste prime tre righe abbiamo settato la porta 

A0 come uscita in push-pull 

LDI pdir_b,00000000B 

LDI popt b,00000010B 

LDI port_b,00000010B 

in queste tre righe abbiamo settato la porta 

B1 come ingresso analogico 

ripeti LDI wdog,255 

carichiamo il watchdog 

LDI adcr,00110000B 

provvedi a convertire da analogico a digitale 

attendi JRR 6,adcr,attendi 

attendere che avvenga la conversione A/D 

LD a.addr 

carica nell’accumulatore A il numero digitale 

CPI a,153 

compara il valore di A con il numero 153 

JRNC accendi 

se A è maggiore di 153 salta all’etichetta accendi 

JRC spegni 

se A è minore di 153 salta all’etichetta spegni 

JP ripeti 

salta all’etichetta ripeti del watchdog 

accendi SET 0,port_a 

setta l’uscita del piedino A0 a 5 volt 

JP ripeti 

salta all’etichetta ripeti del watchdog 

spegni RES 0,port_a 

setta l’uscita del piedino A0 a 0 volt 

JP ripeti 

salta all’etichetta ripeti del watchdog 











Esempio N.15 = Vogliamo accendere una fila di 5 
diodi led, ma in modo che con 1 volt si accenda 
un solo led, con 2 volt si accendano 2 led, con 3 
volt si accendano 3 led ecc., fino a far accendere 
tutti i 5 diodi led quando la tensione raggiunge i 5 
volt. 

Come ingresso analogico abbiamo deciso di sce¬ 
gliere il piedino A7 e come uscite i piedini da BO 

a B4. 

Soluzione: La prima operazione che dobbiamo 
compiere è quello di calcolare il numero decima¬ 
le corrispondente ai valori di tensione di 1 - 2 - 3 - 
4 - 5 volt usando la formula che già conosciamo: 

(1 x 255) : 5 = 51 numero decimale di 1 Volt 

(2 x 255) : 5 = 102 numero decimale di 2 Volt 

(3 x 255) : 5 = 153 numero decimale di 3 Volt 

(4 x 255) : 5 = 204 numero decimale di 4 Volt 

(5 x 255) : 5 = 255 numero decimale di 5 Volt 


A questo punto possiamo programmare il piedino A7 
come ingresso analogico ed i piedini BO - B1 - B2 
- B3 - B4 come uscite push-pull (vedi Tabella N.3). 

Se anziché accendere tutta la fila dei diodi led vo¬ 
lessimo accendere un solo diodo led per volta, cioè 
prima quello su BO, poi quello su B1 - B2 - B3 - B4, 
dovremmo modificare tutte le righe delle etichette 
LED mettendo un 1 solo sul piedino a cui è colle¬ 
gato il led che vogliamo accendere e degli 0 sui pie¬ 
dini a cui sono collegati i led che vogliamo spegnere. 


Nell’esempio che si trova a fine pagina dovremmo 
riscrivere le sole righe LED2 - LED3 - LED4 - LED5 
in questo modo: 


LED2 

LDI 

port_b,00000010B 

LED3 

LDI 

port_b,00000100B 

LED4 

LDI 

port_b,00001000B 

LED5 

LDI 

port_b,00010000B 


PROGRAMMA per Esempio n.15 

LDI pdir_a,00000000B 

LDI popt_a,10000000B 

LDI port_a,10000000B 

in queste tre righe abbiamo settato 
il piedino A7 come ingresso analogico 

LDI pdir b,00011111B 

LDI popt b,00011111B 

LDI port_b,00000000B 

in queste righe abbiamo settato 
i piedini da BO a B4 come uscite 

ripeti LDI wdog,255 

carichiamo il watchdog 

LDI adcr,00110000B 

provvedi a convertire da analogico a digitale 

attendi JRR 6,adcr,attendi 

attendere che avvenga la conversione A/D 

LD a,addr 

carica nell’accumulatore A, il numero digitale 

CPI a, 255 

compara il valore di A con il numero 255 

JRNC LED5 

se A è uguale a 255 salta all’etichetta LED5 

CPI a,204 

compara il valore di A con il numero 204 

JRNC LED4 

se A è maggiore di 204 salta all’etichetta LED4 

CPI a,153 

compara il valore di A con il numero 153 

JRNC LED3 

se A è maggiore di 153 salta all’etichetta LED3 

CPI a,102 

compara il valore di A con il numero 102 

JRNC LED2 

se A è maggiore di 102 salta all’etichetta LED2 

CPI a, 51 

compara il valore di A con il numero 51 

JRNC LEDI 

se A è maggiore di 51 salta all’etichetta LEDI 

JP LEDO 

se A è minore di 51 salta all’etichetta LEDO 

LEDO LDI port_b,00000000B 

non accendere nessun diodo led 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LEDI LDI port_b,00000001B 

accendi il led sul piedino BO 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED2 LDI port_b,00000011B 

accendi i led sui piedini BO - B1 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED3 LDI port_b,00000111B 

accendi i led sui piedini BO - B1 - B2 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED4 LDI port_b,00001111B 

accendi i led sui piedini BO - B1 - B2 - B3 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED5 LDI port_b,00011111B 

accendi i led sui piedini BO - B1 - B2 - B3 - B4 

JP ripeti 

salta all’etichetta ripeti del watchdog 





Questa modifica potrebbe risultare utile se invece 
di accendere dei diodi led volessimo eccitare cin¬ 
que diversi relè per ogni diverso valore di tensio¬ 



Fig.10 Volendo realizzare un Level-Meter 
che accenda una fila di 4 led all’aumentare 
della tensione continua, applicata sul pie¬ 
dino A7 settato come Ingresso, dovrete u- 
tilizzare il programma dell’Esempio N.15 ri¬ 
portato sulla pagina in basso a sinistra. 


ne, ad esempio, il relèl quando la tensione rag¬ 
giunge 1 volt, il relè 2 quando la tensione rag¬ 
giunge i 2 volt ecc. 



Fig.11 Se vorrete eccitare dei relè dovrete 
modificare lo schema come qui sopra ripor¬ 
tato. Per motivi di spazio abbiamo inserito il 
relè solo sul primo transistor in alto. Modifi¬ 
cando il programma potrete utilizzare come 
uscite anche tutti gli 8 piedini della Porta B. 


Fig.12 Per far funzionare un 
qualsiasi micro ST6 della se¬ 
rie 10-20 dovrete collegare sui 
piedini indicati un Quarzo da 
8 MHz, due condensatori ce¬ 
ramici da 22 pF, un elettroliti- 
co da 1 microF e due resi¬ 
stenze da 100.000 ohm. 






Fig.13 Per far funzionare un 
qualsiasi micro ST6 della se¬ 
rie 15-25 dovrete collegare sui 
piedini indicati un Quarzo da 
8 MHz, due condensatori ce¬ 
ramici da 22 pF, un elettroliti- 
co da 1 microF e due resi¬ 
stenze da 100.000 ohm. 





























































TIMER 

Il timer è un contatore collegato al quarzo del mi¬ 
croprocessore tramite un prescaler ed un diviso¬ 
re x 12 (vedi fig.14). 

Per la funzione timer dobbiamo settare due regi¬ 
stri, uno chiamato ter e l’altro tscr. 

Nel registro ter (timer counter register) dovremo in¬ 
serire un numero decimale compreso tra 1 e 255. 
Il ter partendo da questo numero conterà all’in- 
dietro e quando arriverà al numero 0 automatica- 
mente eseguirà tutte le istruzioni comprese tra l’e¬ 
tichetta timjnt e l’istruzione reti. 

Ammesso che si voglia inserire nel registro ter il 
numero 255 dovremmo scrivere questa riga di pro¬ 
gramma: 

LDI ter,255 

Nel registro tscr (timer status control register), che 
controlla il prescaler, dovremo inserire un nume¬ 
ro binario come riportato nella Tabella N.5. 


TABELLA N.5 Registro tscr 


01011000 

divide x 

1 

01011001 

divide x 

2 

01011010 

divide x 

4 

01011011 

divide x 

8 

01011100 

divide x 

16 

01011101 

divide x 

32 

01011110 

divide x 

64 

01011111 

divide x 

128 


Ammesso di voler far dividere il prescaler per 128 
dovremo scrivere questa riga di programma: 


LDI tscr,01011111B 

Alla fine della riga non dobbiamo dimenticarci di in¬ 


serire una B, perché questo è un numero binario. 
Per calcolare il tempo in secondi possiamo usa¬ 
re questa formula: 

secondi = (12 x tscr x ter) : Xtal in Hz 

Ammesso che si usi un quarzo da 8 MHz (pari a 
8.000.000 Hz), che nella riga tscr si sia inserito il 
numero 128 e nella riga ter il numero 255, otterre¬ 
mo un tempo massimo di: 

(12 x 128 x 255) : 8.000.000 = 0,0489 secondi 

che corrispondono a 48,9 millisecondi. 

Tempi così ridotti potrebbero servire soltanto per 
realizzare dei generatori di onde quadre, ma cer¬ 
to non dei timer dove normalmente occorrere rag¬ 
giungere dei tempi di minuti o ore. 

Per ottenere dei tempi molto lunghi possiamo 
usare degli accorgimenti come per esempio ricor¬ 
rere all’uso di altre variabili. 

Esempio N.16 = Vorremmo prelevare dal piedino 
A7 degli impulsi di 1 millisecondo, quindi vor¬ 
remmo sapere come impostare il programma. 

Soluzione: Come prima operazione convertiamo i 

millisecondi in secondi dividendoli per 1.000 e co¬ 
sì otteniamo: 

1 : 1.000 = 0,001 secondo 

Quindi calcoliamo quale numero dobbiamo mette¬ 
re nel registro ter con la formula: 

ter = [(Xtal Hz : 12) : tscr] x secondi 

Tenete presente che il numero del ter non deve 
mai risultare maggiore di 255 quindi se questo si 





































verificasse dovrete aumentare il numero di divi¬ 
sione del prescaler. 

Questo numero, che possiamo prelevare dalla Ta¬ 
bella N.5, è 1 - 2 - 4 - 8 - 16 - 32 - 64 -128. 

Ad esempio se scegliamo per tscr il numero 2 ot¬ 
teniamo un ter di: 

[(8.000.000 : 12) : 2] x 0,001 = 333,33 ter 

poiché questo numero è maggiore di 255 dovre¬ 
mo scegliere per tscr un numero maggiore, ad e- 
sempio 4 e così otterremo: 

[(8.000.000 : 12) : 4] x 0,001 = 166,66 ter 

Poiché il microprocessore lavora solo con numeri 
interi, dovremo arrotondarlo sul numero più pros¬ 
simo che nel nostro caso è 167. 

Noi abbiamo scelto per tscr il numero 4, ma pote¬ 
vamo anche scegliere 8-16-32 ecc. tenendo co¬ 
munque presente che più alto è il numero del tscr 
minore risulterà la precisione sul tempo. 
Disponendo dei valori richiesti cioè: 

tscr = 4 

ter = 167 

possiamo calcolare il tempo con la formula: 

secondi = (12 x tscr x ter) : Xtal in Hz 

ottenendo: 

(12 x 4 x 167) : 8.000.000 = 0,001002 secondi 
che corrispondono a: 

0,001002 x 1.000 = 1,002 millisecondi 


Il programma che dobbiamo scrivere per preleva¬ 
re dal piedino A7 questi impulsi è visibile in fondo 
alla pagina. 

Esempio N.17 = Vogliamo prelevare dal piedino 
A7 delle onde quadre che abbiano una frequenza 
di 1.200 Hz, quindi vogliamo sapere come impo¬ 
stare il programma. 

Soluzione: Come prima operazione dobbiamo cal¬ 
colare il tempo in secondi corrispondente alla fre¬ 
quenza di 1.200 Hz e per ottenere questo dato u- 
siamo la formula: 

secondi = (1 : Hz) : 2 

Nel nostro caso otteniamo: 

(1 : 1.200) : 2 = 0,0004 secondi 

Quindi calcoliamo qual è il numero che dobbiamo 
mettere nel registro ter con la formula: 

ter = [(Xtal Hz : 12) : tscr] x secondi 

Poiché nella formula manca il valore del tscr, con¬ 
sultiamo la Tabella N.5 scegliendo uno di questi 
numeri 1 - 2 - 4 - 8 -16 - 32 - 64 - 128. 

Facciamo presente che il valore di ter che ricave¬ 
remo da questa formula non dovrà mai superare il 
numero 255 quindi se risultasse maggiore dovre¬ 
mo usare un tscr maggiore, cioè 4-8-16 ecc. 
(vedi Tabella N.5). 

Nel nostro esempio abbiamo scelto per tscr il 
numero 2 perché otteniamo un valore minore 

di 255. 

[(8.000.000 : 12) : 2] x 0,0004 = 133,33 ter 


PROGRAMMA per Esempio n.16 


LDI 

pdir_a,10000000B 

LDI 

popt_a,10000000B 

LDI 

port_a,00000000B 

SET 

4,ior 

LDI 

ter,167 

LDI 

tscr,01011010B 

main LDI 

wdog,255 

JP 

main 

timjnt LDI 

wdog,255 

LDI 

ter,167 

LDI 

tscr,01011010B 

SET 

7,port_a 

RES 

7,port_a 

RETI 


queste tre righe servono per settare 
il piedino A7 come uscita in push-pull 

abilita l’interrupt quando il ter diventa 0 
numero 167 calcolato per il ter 

numero binario per un fattore di divisione di 4 (Tabella N.5) 

ricarichiamo il watchdog 

salta all’etichetta main 

ricarichiamo il watchdog 

ricarichiamo 167 nel ter per ripetere gli impulsi 

questa riga fa ripartire il contatore 

fa uscire dal piedino A7 un impulso a 5 volt 

riporta il piedino A7 a 0 volt 

ritorna al programma main 




Per prelevare dal piedino A7 delle onde quadre 
che abbiano una frequenza di 1.200 Hz, dovremo 
scrivere il programma come visibile qui sotto. 


tscr = 2 
ter = 133 


Poiché il microprocessore lavora solo con numeri 
interi dovremo arrotondarlo sul numero più pros¬ 
simo che nel nostro esempio è 133. 

Disponiamo così di tutti i dati richiesti: 


PROGRAMMA per Esempio n.17 



LDI 

pdir_a,10000000B 

queste tre righe ci servono per settare 


LDI 

popt_a,10000000B 

il piedino A7 come uscita in push-pull 


LDI 

port_a,00000000B 


SET 

4,ior 

abilita l’interrupt 


LDI 

ter,133 

carica nel ter il numero 133 


LDI 

tscr,01011001B 

numero binario per un fattore di divisione di 2 (Tabella N.5) 

main 

LDI 

wdog,255 

ricarica il watchdog 


JP 

main 

salta all’etichetta main 

timjnt 



etichetta dell’interrupt 


LDI 

wdog,255 

ricarica il watchdog 


LDI 

ter,133 

ricarica 133 nel ter per continuare 


LDI 

tscr,01011001B 

questa riga fa ripartire il contatore 


JRR 

7,port_a,salita 

se A7 è a 0 salta all’etichetta salita 


RES 

7,port_a 

se A7 è a 1 cambia il livello logico a 0 


JP 

continua 

salta all’etichetta continua 

salita 

SET 

7,port_a 

metti il piedino A7 a livello logico 1 

continua 

RETI 


fine dell’interrupt 




Con il microprocessore ST6 si possono realizzare 
un’infinità di circuiti, come ad esempio orologi, con¬ 
tasecondi, timer, antifurto, controlli numerici per 
macchine utensili, termostato, piccoli robot, coman¬ 
di per luci, termometri, inoltre si possono scrivere 
delle parole sui display LCD, convertire dei calcoli 
ecc., e qui ci fermiamo perché volendo elencare tut¬ 
to ci vorrebbero non poche pagine della rivista. 
Anche se nelle riviste precedenti vi abbiamo spie¬ 
gato le istruzioni per scrivere un programma, per 
chi è all’inizio queste informazioni potrebbero ri¬ 
sultare ancora insufficienti. 

Infatti chi volesse realizzare un orologio a display 
potrebbe trovarsi in difficoltà nel far apparire i nu¬ 


meri delle ore e dei minuti. Se poi in sostituzione 
di un display a sette segmenti si volesse utilizzare 
un display LCD, non si saprebbe quali modifiche 
apportare al software. 

Chi vuole eccitare un relè ad una determinata 
ora si chiederà invece quale istruzione gli permet¬ 
te di ottenere questa condizione. 

Anche ammesso di aver scritto tutte le istruzioni ri¬ 
chieste, il lettore desidera giustamente sapere se 
il suo programma è in grado di eseguire senza er¬ 
rori tutte le funzioni per cui è stato scritto, ha cioè 
bisogno di testarlo e per questo gli servono delle 
schede di test universali. 

Sono proprio queste che prenderemo in esame con 







Fig.1 Foto del bus proget¬ 
tato per testare i micro 
ST6. 

I due costosi zoccoli tex- 
tool possono essere sosti¬ 
tuiti con due economici 
zoccoli per integrati, come 
visibile nel disegno pratico 
di fig.3. 









TESTARE i micro $T6 


Il primo problema che si presenta a quanti desiderano iniziare a scrive¬ 
re del software personalizzato per i microprocessori ST6 della SGS, è 
quello di poter controllare il programma per verificare che esegua le fun¬ 
zioni richieste. Per aiutarvi abbiamo progettato delle schede sperimen¬ 
tali, che saranno particolarmente utili agli Istituti Tecnici se usate come 
supporto al consueto materiale didattico. 


il nostro articolo. 

A parte vi forniamo un dischetto contenente alcu¬ 
ni programmi completi di esaurienti commenti, che 
potranno servirvi per realizzare orologi, timer, con¬ 
tasecondi, antifurto ecc., e con riportate tutte le mo¬ 
difiche che si possono apportare. 

Come sempre i maligni penseranno che il nostro 
obiettivo sia solo quello di vendere al lettore un di¬ 
schetto, ma essi non considerano che riempire 10 
pagine della rivista con sole righe di programma 
non risulta per nulla gradito a coloro ai quali non 
interessa l’ST6. 

Inoltre non pensano che nel trascrivere i program¬ 
mi sulla rivista si possono verificare degli errori di 
stampa, ed altri errori possono commetterli gli stes¬ 
si lettori nel ricopiare le istruzioni. 

Disponendo di un dischetto con programmi già te¬ 
stati, il lettore potrà subito metterli in funzione e poi 
modificarli secondo le proprie esigenze. 

Se con le modifiche apportate il programma darà 
qualche errore, sarà sempre possibile fare un con¬ 


trollo con il programma originale per verificare do¬ 
ve è stato commesso l’errore. 


IMPORTANTE 

La SGS ci ha comunicato che cesserà di produrre 
i microprocessori riprogrammabili tipo ST62E10 
e tipo ST62E15, entrambi da 2 K di memoria, per¬ 
ché tutte le Industrie chiedono e preferiscono uti¬ 
lizzare i riprogrammabili da 4 K di memoria an¬ 
che se più costosi. 

I microprocessori non riprogrammabili tipo 
ST62T10 - ST62T15 con 2 K di memoria rimar¬ 
ranno invece sempre in produzione. 

Pertanto fuori produzione andranno i tipi: 

ST62E10 che verranno sostituiti dagli ST62E20 
ST62E15 che verranno sostituiti dagli ST62E25 

Poiché le dimensioni e la piedinatura dei due mo- 







ELENCO COMPONENTI LX.1202 

RI = 100.000 ohm 1/4 watt 
R2 = 100.000 ohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 1 mF elettr. 63 volt 
C3 = 22 pF ceramico 
C4 = 22 pF ceramico 


C5 = 100.000 pF poliestere 
C6 = 100 mF elettr. 35 volt 
XTAL = quarzo 8 MHz 
DS1 = diodo 1N.4007 
DS2 = diodo 1N.4007 
CONN.1-2-3 = connettori 24 poli 
PI = pulsante 


Fig.2 Schema elettrico del circuito bus progettato per testare i programmi per i mi¬ 
croprocessori ST6. Anche se nel bus sono presenti due zoccoli, dovrete sempre uti¬ 
lizzarne uno SOLO alla volta, quindi prima di inserire un micro in uno zoccolo dovre¬ 
te togliere quello presente sull’altro zoccolo. 

Il bus andrà alimentato con lo stadio di alimentazione visibile nelle figg.4-7 cercando 
di non invertire i due fili dei 5,6 e 12,6 volt. 
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Fig.3 Schema pratico di montaggio del bus. Potete sostituire i due comuni zoccoli per 
i microprocessori ST6 con i più comodi, ma costosi textool (vedi fig.1). 






















































delli risultano identiche sarà possibile sostituirli 
senza problemi. 

Il motivo per cui tutti preferiscono i microprocesso¬ 
ri riprogrammabili da 4 K è ovvio. 

I microprocessori riprogrammabili servono e ven¬ 
gono utilizzati unicamente per testare i programmi 
e quindi possono essere cancellati e riutilizzati per 
provare altri programmi. 

Dopo aver verificato che il programma funziona, si 
può definitivamente trasferirlo sui microprocessori 

non riprogrammabili tipo ST62T10 - ST62T20 o 
ST62T15 - ST62T25. 

Poiché un microprocessore riprogrammabile vie¬ 
ne riutilizzato un centinaio di volte, si preferisce 
acquistarne uno da 4 K, perché può essere usato 
sia per i programmi che occupano 1 - 1,5 - 2 K sia 
per quelli che occupano 2,5 - 3 - 4 K. 


ELENCO COMPONENTI LX.1203 

CI = 2.200 mF elettr. 35 volt 
C2 = 100.000 pF poliestere 
C3 = 100.000 pF poliestere 
C4 = 100 mF elettr. 35 volt 
C5 = 2.200 mF elettr. 35 volt 
C6 = 100.000 pF poliestere 
C7 = 100.000 pF poliestere 
C8 = 100 mF elettr. 35 volt 
DS1 = diodo 1N.4007 
DS2 = diodo 1N.4007 
RS1 = ponte raddr. 100 V. 1 A. 

RS2 = ponte raddr. 100 V. 1 A. 

IC1 = uA.7812 
IC2 = uA.7805 

TI = trasformatore 25 watt (T025.01) 
sec. 14 V. 1 A. - 8 V. 1 A. 

SI = interruttore 


SCHEMA ELETTRICO scheda BUS 

Per testare i programmi abbiamo realizzato una 
scheda in cui si possono utilizzare sia i micropro¬ 
cessori da 20 piedini sia quelli da 28 piedini. 

Per questa scheda abbiamo inoltre realizzato un 
bus che porta tutti i segnali del microprocessore ai 
connettori femmina sui quali potrete inserire diver¬ 
si tipi di schede, ad esempio con dei display a 7 
segmenti, oppure con un display LCD o con dei 
relè o ancora con dei Triac. 



w 

EMÙ 

uA 7805 
uA 7812 


Fig.5 Connessioni dei 
due integrati stabilizza¬ 
tori di tensione. 









































Fig.6 Disegno del circuito stampato dello stadio di alimentazione siglato LX.1203 visto dal 
lato rame. Nota: il disegno è stato leggermente ridotto per farlo rientrare nella pagina; le 
sue misure reali sono Lunghezza = mm 160 ed Altezza = mm 70. 
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Fig.7 Schema pratico di montaggio dello stadio di alimentazio¬ 
ne. I due integrati stabilizzatori IC1-IC2 vanno fissati sopra le a- 
lette di raffreddamento come visibile in fig.8. La tensione alter¬ 
nata dei 14 volt, disponibile nella morsettiera a 2 poli, vi servirà 
per testare i circuiti con Triac o Scr. 

















































Per la descrizione dello schema elettrico, visibile in 
fig.2, iniziamo proprio dai due zoccoli, che, ovvia¬ 
mente, dovranno essere utilizzati solo uno per vol¬ 
ta. 

Dunque se avete già inserito un microprocessore 
in uno zoccolo, per inserirne un altro nel secondo 
zoccolo dovrete togliere il primo. 

Tutti i terminali dei due zoccoli sono collegati tra lo¬ 
ro in modo da sfruttare per entrambi lo stesso quar¬ 
zo per il clock, lo stesso pulsante di reset ed ov¬ 
viamente la stessa alimentazione. 

Anche tutte le porte d’ingresso/uscita sono colle¬ 
gate in parallelo e qui è necessario ricordare che 
nello zoccolo che riceverà i microprocessori 
ST62E10 - ST62E20 la porta A inizia da AO e ter¬ 
mina ad A3, la porta B inizia da BO e termina a 
B7, e che manca la porta C. 

Nello zoccolo che riceverà i microprocessori 
ST62E15 - ST62E25 risultano presenti tutte le por¬ 
te da AO ad A7 e da BO a B7, e la porta C inizia 
da C4 e termina a C7. 

Tutti gli ingressi/uscite raggiungono i connettori 
femmina CONN.1 - CONN.2 - CONN.3 nei quali 
andranno inserite le schede sperimentali. 
Sempre sugli stessi connettori risultano presenti 
le piste di alimentazione, cioè 5,6 volt positivi - 
12,6 volt positivi e la massa. 

I diodi al silicio DS1 - DS2, posti in serie sui due 
ingressi di alimentazione, sono stati inseriti per 
evitare di danneggiare il micro nel caso venisse 
applicata su questi terminali una polarità opposta 
a quella richiesta. 

Poiché questi diodi introducono una tensione di cir¬ 
ca 0,6 volt, applicando sull’ingresso una tensione 
di 5,6 volt e 12,6 volt, in uscita si otterranno e- 
sattamente 5 volt e 12 volt. 


REALIZZAZIONE PRATICA 

Sul circuito stampato siglato LX.1202 dovete mon¬ 
tare i pochi componenti visibili in fig.3. 

Come noterete, nel kit abbiamo inserito due zoc¬ 
coli, uno da 20 e l’altro da 28 piedini, ma qui dob¬ 
biamo aprire una piccola parentesi. 

Poiché questo progetto verrà utilizzato anche da 
piccole e medie Industrie per testare i loro micro- 
processori, noi consigliamo di utilizzare, in sostitu¬ 
zione degli zoccoli inseriti nel kit, degli zoccoli tex- 
tool provvisti di una levetta di bloccaggio (vedi 
fig.1). 

Usando questi zoccoli risulterà più semplice e ve¬ 
loce inserire e togliere i microprocessori, ma que¬ 
sto vantaggio costerà 55.000 lire in più. 



Fig.8 Come si presenta a montaggio ulti¬ 
mato lo stadio di alimentazione che vi for¬ 
nisce tutte le necessarie tensioni per ali¬ 
mentare il nostro bus. 

Vi consigliamo di racchiudere ralimentato- 
re dentro un mobile plastico e a questo pro¬ 
posito vi indichiamo il mobile codificato 
MTK06.22 del costo di € 6,97 






Come visibile in fig.3, sullo stampato dovrete mon¬ 
tare i due zoccoli, il pulsante di reset, il quarzo, i 
connettori per le schede sperimentali ed i pochi 
componenti passivi, cioè resistenze, condensatori 
ed i due diodi al silicio, rispettando il verso della fa¬ 
scia bianca riportata sul loro corpo. 

I quattro connettori femmina a 4 terminali, che sul¬ 
lo stampato risultano isolati dal circuito, serviranno 
come punto di appoggio per le schede speri¬ 
mentali che inserirete nel bus. 

Questi connettori vi serviranno anche per evitare di 
inserire le schede sperimentali in senso inverso al 
richiesto. 


ALIMENTAZIONE 

Le tensioni richieste per alimentare questo bus de¬ 
vono risultare, come già anticipato, di 5,6 e di 12,6 
volt. 

Come visibile in fig.4, le due tensioni prelevate dai 
due secondari del trasformatore TI vengono rad¬ 
drizzate da RS1 ed RS2, poi stabilizzate a 5,6 volt 
dall’integrato uA.7805 (vedi IC2) e a 12,6 volt 
dall’integrato uA.7812 (vedi IC1). 

Per prelevare sull’uscita di questi due integrati una 
tensione di 5,6 volt anziché di 5 volt ed una ten¬ 
sione di 12,6 volt anziché di 12 volt, abbiamo in¬ 
serito tra il terminale M e la massa un diodo al si¬ 
licio (vedi DS1 - DS2). 

Dallo stesso trasformatore si preleva anche una 
tensione alternata di circa 14 volt, che potrà ser¬ 
vire per testare i circuiti che utilizzano dei Triac. 
Anche se per queste prove è possibile applicare 
sulla loro uscita una tensione di 220 volt alterna¬ 
ti, noi ve lo sconsigliamo, perché se inavvertita¬ 
mente toccaste con le mani le piste del circuito 
stampato potrebbe risultare molto pericoloso. 


REALIZZAZIONE PRATICA ALIMENTATORE 

Sul circuito stampato monofaccia siglato LX.1203 
monterete tutti i componenti visibili in fig.7 cercan¬ 
do come sempre di rispettare la polarità dei termi¬ 
nali dei diodi al silicio, dei ponti raddrizzatori e dei 
condensatori elettrolitici. 

Come potete osservare anche dalle foto, i due in¬ 
tegrati stabilizzatori vanno fissati sopra due alette 
di raffreddamento. 

Per le tensioni d’uscita inserite una morsettiera a 
3 poli dalla quale potrete prelevare le tensioni sta¬ 
bilizzate di 12,6 volt - 5,6 volt più il filo della mas¬ 
sa, ed una morsettiera a 2 poli dalla quale potre¬ 
te prelevare una tensione alternata di circa 14 volt 


che vi servirà per collaudare i programmi che “pi¬ 
lotano” i diodi Triac. 

Vi conviene racchiudere l’alimentatore dentro un 
qualsiasi mobile e a tal proposito vi consigliamo il 
mobile siglato MTK06.22. 

Per le tensioni d’uscita utilizzate dei fili di diverso 
colore così da poter subito stabilire il valore della 
tensione presente e non correre il rischio di inver¬ 
tirli quando li collegherete alla morsettiera del bus. 
Tanto per fare un esempio, per la massa potrete 
scegliere il colore nero, per i 5,6 volt il colore gial¬ 
lo o marrone e per i 12,6 volt il colore rosso o a- 
rancio. 

Per i due fili dell’alternata potrete usare due fili 
bianchi oppure di un colore completamente diver¬ 
so da quello scelto per le altre uscite. 

Per le schede sperimentali vi rimandiamo all’arti¬ 
colo pubblicato su questa stessa rivista. 


COSTO DI REALIZZAZIONE 

Il solo Bus siglato LX.1202 completo di cir¬ 
cuito stampato, quarzo, zoccoli normali, con¬ 
nettori, pulsante, cioè tutti i componenti visibili in 


fig.3 (sensa textool).€ 25,80 

Costo del solo stampato LX.1202.€ 17,04 


Costo di uno zoccolo textool a 20 piedini € 19,63 
Costo di uno zoccolo textool a 28 piedini € 28,41 

Il solo stadio di alimentazione siglato LX.1203 com¬ 
pleto di circuito stampato, due integrati stabilizza¬ 
tori, alette di raffreddamento, due ponti raddrizza¬ 
tori, cordone di alimentazione e relativo trasforma¬ 


tore.€ 25,80 

Costo del solo stampato LX.1203.€ 4,34 


Vi consigliamo di racchiudere lo stadio di alimen¬ 
tazione dentro un mobile plastico e a tale scopo vi 
proponiamo il modello MTK06.22. 

Costo del mobile MTK06.22.€ 6,97 

Ai prezzi riportati andranno aggiunte le sole spese 
di spedizione a domicilio. 








Inserendo queste due schede nel bus siglato 
LX.1202, riportato su questo numero, e collocan¬ 
do nel suo zoccolo un microprocessore ST6, che 
voi stessi potrete programmare copiando uno dei 
programmi di esempio presenti nel dischetto che 
vi forniremo, potrete ottenere orologi - contase¬ 
condi - timer - cronometri - contaimpulsi ecc. 
Poiché i nostri programmi di esempio si possono 
facilmente modificare, riuscirete in breve tempo a 
capire come scriverne altri per ottenere funzioni che 
noi attualmente non abbiamo previsto. 

Queste schede risulteranno quindi utilissime per te¬ 
stare tutti i programmi che scriverete, perché ve¬ 
drete dal vivo se appaiono i numeri desiderati e 
se i relè si eccitano o si diseccitano nei tempi pre¬ 
visti. 

A queste schede ne seguiranno via via altre che u- 
tilizzeranno i display LCD ed i diodi TRIAC. 
Entrerete così in possesso di un valido banco di 
test per tutti i tipi di programmi per microproces¬ 
sori ST6. 


Sul piedino 22 di data vanno inviati dei bit seriali, 
che l’integrato M.5450 convertirà in bit paralleli ne¬ 
cessari per accendere i segmenti dei quattro di¬ 
splay. 

La sequenza dei bit necessari per accendere i seg¬ 
menti dei display deve essere preceduta da un bit 
di start (vedi fig.1). 

In pratica all’integrato giunge una sequenza di 37 
bit come qui sotto riportato: 

1 bit di Start 

32 bit per accendere i display 

2 bit per accendere i diodi led 
2 bit di fine caricamento 

I segmenti dei quattro display e dei due diodi led 
si accendono soltanto quando all’integrato sono 
giunti tutti i 37 bit, vale a dire tutta la sequenza so¬ 
pra riportata compresi gli ultimi 2 bit di fine cari¬ 
camento. 


SCHEDATESI per ST6 


SCHEDA DISPLAY 


Lo schema elettrico di questa scheda, riportato in 
fig.6, è molto semplice, perché utilizza il solo inte¬ 
grato M.5450 (vedi IC1) necessario per pilotare 4 

display. 

Nel caso realizzaste un orologio, i due pulsanti 
presenti nel circuito vi potranno servire per mette¬ 
re a punto le ore ed i minuti, mentre i due diodi 
led potrebbero visualizzare i secondi oppure po¬ 
treste impiegarli per altre funzioni da assegnare tra¬ 
mite software. 

Il trimmer siglato RI serve soltanto per variare la 
luminosità dei display. 

Poiché desideriamo che il lettore sappia come si 
riesca a far accendere un qualsiasi numero sui 4 
display collegando due soli fili all’integrato M.5450 
(vedi piedini 22 - 21 ), dobbiamo a questo punto spie¬ 
gare come vanno gestiti questi piedini. 

Sul piedino 21 di clock va applicata una frequen¬ 
za ad onda quadra che faremo generare dall’ST62 
inserendo nel programma le due istruzioni Set-Res 
(vedi righe 119-120 nel programma DISPLAY.A- 
SM presente nel dischetto). 


Se guardate la fig.1, in cui sono riportati tutti i 7 
segmenti di un display contrassegnati da una let¬ 
tera, potrete ricavare dalla Tabella N.1 i bit che 
devono giungere al piedino 22 dell’integrato per 
accendere i vari segmenti. 

Il bit, come già sapete, è una cifra binaria che può 
assumere un livello logico 0 oppure un livello lo¬ 
gico 1. 

Per accendere i segmenti interessati, i bit che en¬ 
trano sul piedino 22 devono avere un livello lo¬ 
gico 1. 

E’ poi l’integrato che provvede a commutare le sue 
uscite a livello logico 0 in modo che i segmenti 
ed i diodi led risultino alimentati. 

Quindi se volessimo accendere il numero 7 sul di¬ 
splay N.4, sull’ingresso di IC1 dovremmo far giun¬ 
gere la sequenza di bit visibile in fig.2. 

Se invece volessimo accendere il numero 7 sul di¬ 
splay N.1, dovremmo far giungere sull’ingresso di 
IC1 la sequenza di bit visibile in fig.3. 

Nel dischetto che vi forniremo abbiamo inserito un 
programma chiamato DISPLAY per mostrarvi co¬ 
me si possa accendere qualsiasi numero in uno 
dei quattro display. 



Potrete utilizzare queste due schede come orologio, contasecondi, ti¬ 
mer, cronometro, contaimpulsi, e se questo non bastasse potrete ecci¬ 
tare, nei tempi da voi desiderati, dei relè per pilotare una cicalina o per 
alimentare una qualsiasi apparecchiatura elettrica. 



SCHEDA RELÈ 

Lo schema elettrico di questa scheda, riportato in 
fig.9, utilizza solo 4 relè pilotati da altrettanti tran¬ 
sistor. 

In teoria avremmo potuto inserire ben 20 relè uti¬ 
lizzando così tutte le porte A - B - C, ma poiché 
questa scheda viene inserita nel bus assieme alla 


scheda dei display, che già utilizza le porte B0 - 
B1 - B2 - B3, non potevamo servirci della stessa 
porta per accendere un display ed eccitare un relè. 
I vari relè si eccitano quando sulle porte B4 - B5 
- B6 - B7 è presente un livello logico 1, che, po¬ 
larizzando le Basi dei transistor, li portano in con¬ 
duzione. 

A relè eccitato si accende il diodo led applicato 

















TABELLA N. 1 


DISPLAY N. 4 


Bit 

piedino 

IC1 

segmento 

display 

9 

10 

A 

10 

9 

B 

11 

8 

C 

12 

7 

D 

13 

6 

E 

14 

5 

F 

15 

4 

G 

16 

3 

punto 


DISPLAY N. 3 


Bit 

piedino 

IC1 

segmento 

display 

i 

18 

A 

2 

17 

B 

3 

16 

C 

4 

15 

D 

5 

14 

E 

6 

13 

F 

7 

12 

G 

8 

11 

punto 


DISPLAY N. 2 


Bit 

piedino 

IC1 

segmento 

display 

25 

33 

A 

26 

32 

B 

27 

31 

C 

28 

30 

D 

29 

29 

E 

30 

28 

F 

31 

27 

G 

32 

26 

punto 


DISPLAY N. 1 


Bit 

piedino 

IC1 

segmento 

display 

17 

2 

A 

18 

40 

B 

19 

39 

C 

20 

38 

D 

21 

37 

E 

22 

36 

F 

23 

35 

G 

24 

34 

punto 


ai suoi capi, quindi se sulla morsettiera d’uscita 
applicheremo una lampadina o un motorino, ali¬ 
mentati con una qualsiasi tensione esterna sia in 
continua sia in alternata, la lampada si accen¬ 
derà ed il motorino inizierà a girare. 

I pulsanti PI - P2 - P3 - P4, collegati alle porte AO 
- Al - A2 - A3, sono stati inseriti per diseccitare o 
eccitare manualmente uno dei quattro relè. 

REALIZZAZIONE PRATICA DISPLAY 

Sul circuito stampato siglato LX.1204 monterete i 
pochi componenti visibili in fig.7. 

Per iniziare consigliamo di inserire lo zoccolo per 
l’integrato IC1, poi, dal lato opposto dello stampa¬ 
to, inserite il connettore maschio ad 1 fila provvi¬ 
sto di 24 terminali e gli altri due connettori maschi, 
sempre ad 1 fila, provvisti di 4 terminali, che in se¬ 
guito vi serviranno per innestare questa scheda sui 
connettori femmina della scheda bus siglata 
LX.1202. 

Dopo aver stagnato questi componenti, potete in¬ 
serire le due resistenze, i quattro condensatori, il 
trimmer RI ed i due pulsanti PI - P2. 
Proseguendo nel montaggio inserite i due diodi led 
rivolgendo il terminale più lungo, cioè l’Anodo, 
verso sinistra. 

Se invertirete questo terminale, i diodi led non si 
accenderanno. 

Per completare il montaggio dovrete saldare diret¬ 
tamente sul circuito i quattro display, controllando 
che il lato in cui è presente il punto decimale ri¬ 
sulti rivolto verso il basso, cioè verso l’integrato IC1. 
Dopo aver inserito tutti i componenti, dovete inse¬ 
rire nel suo zoccolo l’integrato M.5450 rivolgendo 
la sua tacca di riferimento ad U verso sinistra, co¬ 
me risulta visibile in fig.7. 

REALIZZAZIONE PRATICA RELÈ 

Sul circuito stampato siglato LX.1205 monterete 
tutti i componenti visibili in fig.10. 

Per il montaggio vi consigliamo di iniziare inseren- 


DIODO LED 


Bit 

piedino IC1 

diodi led 

34 

24 

DL2 

33 

25 

DL1 


Con queste tabelle potrete sapere quali bit devono giungere sul piedino 22 dell’integrato 
M.5450 (vedi fig.4) per accendere i sette segmenti dei quattro display ed i due diodi led. 





































juuuuuuuuuuuuuuuuuuuuul^^ ZZ 

START 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 RESET 

n nn DATA 

—I I-1 U I PIN22 


Fig.1 Sul piedino 22 dell’integrato M.5450 giunge un primo bit di 
Start. A questo seguono 32 bit per accendere i segmenti dei di¬ 
splay, 2 bit per accendere i led e 2 bit di fine caricamento. I sette 
segmenti del display sono identificati da una lettera (vedi A-B-C- 
D-E-F-G) quindi per visualizzare il numero 7 dovrete alimentare i 
segmenti A-B-C e per visualizzare il numero 3 dovrete alimentare 
i segmenti A-B-G-C-D. 



juuuuuuuuuuuuuuuuuuuuuuuuui^^ Z £ 

START 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 RESET 

_n_rum_n_n_ Zn 

N. 7 SU DISPLAY 4 

Fig.2 Per accendere il numero 7 sul display 4 dovrete far giungere sull’integrato M.5450 
questa sequenza di bit seriali. Con i bit 9-10-11 verranno alimentati i soli segmenti A-B-C 
del display n.4 (vedi Tabella posta sulla sinistra). 

JUUUUUUUUUUUUUUUUUUUUUUUU^ Z * 

START 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 RESET 

nini ir _ il n _ nn n nn __ ni n n_ P D ™ 

N. 7 SU DISPLAY 1 L0AD 

Fig.3 Per accendere il numero 7 sul display 1 dovrete far giungere sull’integrato M.5450 
questa sequenza di bit seriali. Con i bit 17-18-19 verranno alimentati i soli segmenti A-B- 
C del display n.1 (vedi Tabella posta sulla sinistra). 



GND 
BIT 17 
BIT 16 
BIT 15 
BIT 14 
BIT 13 
BIT 12 
BIT 11 
BIT 10 
BIT 9 
BIT 8 
BIT 7 
BIT 6 
BIT 5 
BIT 4 
BIT 3 
BIT 2 
BIT 1 
LUMIN. 
+ Vcc 


BIT 18 
BIT 19 
BIT 20 
BIT 21 
BIT 22 
BIT 23 
BIT 24 
BIT 25 
BIT 26 
BIT 27 
BIT 28 
BIT 29 
BIT 30 
BIT 31 
BIT 32 
BIT 33 
BIT 34 
ENABLE 
DATA 
CLOCK 


M 5450 


Fig.4 Schema a blocchi dell’integrato M.5450 e connessioni dei piedini sullo zoccolo vi¬ 
ste da sopra. Entrando con un segnale seriale nel piedino 22 di questo integrato voi po¬ 
trete accendere i segmenti dei 4 display (vedi fig.6). 
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Fig.5 Foto della scheda di¬ 
splay notevolmente rimpic¬ 
ciolita per motivi di spazio. 
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Fig.6 Schema elettrico della scheda display. I segmenti dei display si accendo¬ 
no quando il piedino d’uscita dell’integrato si porta a livello logico 0. 


ELENCO COMPONENTI LX.1204 

RI = 50.000 ohm trimmer 
R2 = 10.000 ohm 1/4 watt 
R3 = 10.000 ohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 1.000 pF poliestere 
C3 = 100.000 pF poliestere 


C4 = 100.000 pF poliestere 
DL1 = diodo led 
DL2 = diodo led 

DISPLAY1-4 = display tipo BS.A501 

IC1 = M.5450 

P1-P2 = pulsanti 

CONN.1/2 = connettore 24 poli 













































do, dal lato opposto a quello dei componenti, il con¬ 
nettore maschio ad 1 fila provvisto di 24 termina¬ 
li e gli altri due connettori maschi, sempre ad 1 fi¬ 
la, provvisti di 4 terminali, che in seguito vi servi¬ 
ranno per innestare questa scheda sui connettori 
femmina della scheda bus siglata LX.1202. 

Ora voltate lo stampato e sulla parte inferiore del 
circuito inserite tutte le resistenze, poi i diodi al 
silicio non dimenticando di rivolgere il lato contor¬ 
nato da una fascia nera verso le morsettiere di u- 
scita. 

Proseguendo nel montaggio inserite tutti i con¬ 
densatori, poi tutti i transistor rivolgendo la parte 
piatta del loro corpo verso sinistra come visibile 
nello schema pratico di fig.10. 

Completata questa operazione, potete inserire i 
quattro pulsanti, i quattro relè e le quattro mor¬ 
settiere a 2 poli. 

Per ultimi montate i diodi led non dimenticando di 
rivolgere il terminale più lungo dell’Anodo verso i 
relè. 

Le quattro morsettiere presenti nello stampato so¬ 
no collegate ai contatti dei relè, perciò quando il 
relè si ecciterà il contatto si chiuderà e pertanto lo 
potrete utilizzare come interruttore per accende¬ 
re lampadine, alimentare motorini o trasforma¬ 
tori oppure dei servorelè a 220 volt. 


L’ultimo connettore femmina, posto sulla parte su¬ 
periore dello stampato LX.1202, è stato previsto 
nell’eventualità che vogliate collegare un vostro 
personale circuito stampato oppure per prolunga¬ 
re il bus. 


I PROGRAMMI 

Il nuovo dischetto che vi forniremo è in pratica lo 
stesso che abbiamo distribuito in precedenza (ve¬ 
di rivista N.172/173), con la differenza che oltre ai 
programmi: 

CONTA. ASM 
LED.ASM 
LOTTO.ASM 
STANDARD.ASM 

abbiamo aggiunto questi nuovi files: 

RELE.ASM 

DISPLAY.ASM 

OROLOGIO.ASM 

CRONOMET.ASM 

TEMPOR.ASM 

TIMER.ASM 


INSERIMENTO SCHEDE nel BUS 

Potete inserire queste schede nel bus siglato 
LX.1202 indifferentemente su uno dei due connet¬ 
tori femmina presenti sullo stampato. 


Ogni riga di programma è stata completata da un 
commento che spiega la funzione dell’istruzione e 
quindi permette di sapere come modificare il pro¬ 
gramma per fargli compiere una funzione diversa 
da quella per cui era stato scritto. 


DISPLAY! DISPLAY2 DL2 0ISPLAY3 QISPLAY4 



C0NN.1-2 ^ 


Fig.7 Schema pratico di montaggio della scheda display siglata LX.1204. Quando inseri¬ 
te i display rivolgete il loro “punto decimale” verso l’integrato IC1. 





















































Fig.8 Foto ridotta 
della scheda relè. 


USCITA 1 



Fig.9 Schema elettrico della scheda relè siglata LX.1205 e connessioni del transistor 
BC.547 viste da sotto. Potrete utilizzare i relè per alimentare motorini o lampade. 


ELENCO COMPONENTI LX.1205 

RI = 2.200 ohm 1/4 watt 
R2 = 10.000 ohm 1/4 watt 
R3 = 680 ohm 1/4 watt 
R4 = 2.200 ohm 1/4 watt 
R5 = 10.000 ohm 1/4 watt 
R6 = 680 ohm 1/4 watt 
R7 = 2.200 ohm 1/4 watt 


R8 = 10.000 ohm 1/4 watt 
R9 = 680 ohm 1/4 watt 
RIO = 2.200 ohm 1/4 watt 
RII = 10.000 ohm 1/4 watt 
RI2 = 680 ohm 1/4 watt 
RI3 = 10.000 ohm 1/4 watt 
RI4 = 10.000 ohm 1/4 watt 
RI5 = 10.000 ohm 1/4 watt 


RI 6 = 10.000 ohm 1/4 watt 
C1-C4 = 100.000 pF poliestere 
DS1-DS4 = diodi 1N.4150 
DL1-DL4 = diodi led 
TR1-TR4 = NPN tipo BC.547 
RELE’1-4 = relè 12 volt 
P1-P4 = pulsanti 
CONN.1/2 = connettore 24 poli 






























































Tanto per fare un esempio, se nel programma TI¬ 
MER volete variare i tempi di eccitazione dei relè, 
troverete spiegato in quale riga va modificata l’i¬ 
struzione e quale numero occorre inserire. 

Se volete che il programma TIMER ecciti un relè 
per far suonare un campanello o per accendere u- 
na caldaia ad una precisa ora, vi verrà spiegato 
quale riga modificare per migliorare in base alle vo¬ 
stre personali esigenze la funzionalità del pro¬ 
gramma. 


TRASFERIMENTO file nell’HARD-DISK 


Se il computer vi comunica che questa directory e- 
siste già, non preoccupatevi e premete due volte 
il tasto S. 

A questo punto inizia la scompattazione dei files 
(vedi fig.11) ed al termine dell’operazione vedrete 
apparire sul monitor la scritta: 

Buon divertimento 

Premendo un tasto qualsiasi, sul monitor apparirà 
la scritta: 

C:\ST6> 


Una volta inserito il dischetto nel drive floppy, per 
trasferire tutti i suoi files nell’Hard-Disk dovete scri¬ 
vere: 

C:\>A: poi Enter 
A:\>INSTALLA poi Enter 

Non usate mai l’istruzione Copy del Dos o altri co¬ 
mandi analoghi del PCshell - PCtooIs - Norton o 
il File Manager di Windows, perché il programma 
INSTALLA presente nel dischetto provvede a 
scompattare automaticamente i files inseriti. 

Dopo aver pigiato Enter apparirà la scritta: 

Directory C:\ST6 


Nel dischetto che vi abbiamo preparato, abbiamo 
incluso un semplice Editor che vi sarà molto utile 
per visualizzare tutte le righe di ogni programma, 
e, se lo desiderate, per modificarle. 

Potrete usare lo stesso Editor per scrivere nuovi 
programmi, ed anche per assemblarli prima di tra¬ 
sferirli nella memoria del microprocessore ST6 tra¬ 
mite il nostro programmatore siglato LX.1170 pre¬ 
sentato sulla rivista N.172/173. 

Tutte le istruzioni per utilizzare l’Editor sono state 
già descritte nella rivista N.172/173, in particolare 
nell’articolo sul Circuito Test a pag.56, quindi vi 
consigliamo di rileggere attentamente questo arti¬ 
colo. 



Fig.10 Schema pratico di montaggio della scheda LX.1205. Potrete modificare il pro¬ 
gramma di base che troverete nel dischetto in modo da adattarlo alle vostre esigenze. 












































Nelle pagine seguenti ci limiteremo infatti a descri¬ 
vervi le istruzioni più importanti. 

DUPLICARE un FILE con NOME diverso 

Anziché modificare i files che trovate nel dischet¬ 
to, vi consigliamo di ricopiarli nell’Hard-Disk con 
un nome diverso, e di apportare su questo nuovo 
file le modifiche che riterrete opportune. 

In questo modo avrete sempre a disposizione, in 
caso di bisogno, il programma originale. 

Ammesso che vogliate duplicare il file DISPLAY, 
dovrete innanzitutto scegliere un nome che non ab¬ 
bia più di 8 caratteri, ad esempio DPLPROVA. 
Quando siete nel menu principale del nostro Edi¬ 
tor: 

premete ALT+F 
poi pigiate D 

apparirà la scritta C:\ST6> 

A questo punto potete scrivere l’istruzione: 

C:\ST6>Copy DISPLAY.ASM DPLPROVA.ASM 

poi premete Enter. 

Dopo pochi secondi apparirà la scritta: 

1 file copiato 

Per ritornare al menu principale dovrete scrivere: 
C:\ST6>EXIT poi Enter 

Ora con il tasto funzione F3 potrete richiamare il fi¬ 
le DPLPROVA sul quale potrete apportare tutte le 
modifiche che riterrete opportune. 

PER MODIFICARE un PROGRAMMA 

Premendo il tasto funzione F3, quando siete nel 
menu principale, appare sul monitor una finestra 
con l’intero elenco dei programmi. 

Premendo prima il tasto TAB e poi i tasti freccia 
potrete portare il cursore sui nomi dei programmi. 
Quando il cursore si trova sul programma che vo¬ 
lete modificare, premete Enter ed apparirà il lista¬ 
to completo del programma selezionato. 

Per cancellare una sola parola 

pigiate i tasti CTRL+T. 

Per cancellare un’intera riga 

pigiate i tasti CTRL+Y. 

Dopo aver corretto, modificato, cancellato una 
riga o una parola dovrete ricordarvi di premere il 



tasto funzione F2 per memorizzare tutte le modi¬ 
fiche che avete effettuato. 

ASSEMBLAGGIO del PROGRAMMA 

Un programma corretto, modificato o riscritto, si 

può trasferire in un micro ST6 solo dopo averlo as¬ 
semblato. 

Dopo aver salvato un programma premendo il ta¬ 
sto funzione F2, per assemblarlo dovrete proce¬ 
dere come segue: 

Premete ALT+T 
quindi premete A 

Se nel programma che avete modificato o riscritto 
non è presente nessun errore, dopo pochi secon¬ 
di comparirà sul monitor la scritta: 

***SUCCESS*** 

Se avete commesso qualche errore, apparirà in 
basso a sinistra sul monitor un numero, che corri¬ 
sponde alla riga in cui c’è un errore. 

Dovrete allora riaprire il file ed andare sulla riga 
che vi è stata segnalata per scoprire quale errore 
avete commesso. 

Terminata la correzione, dovrete nuovamente sal¬ 
vare il programma premendo il tasto F2, dopodi¬ 
ché potrete ripetere i comandi già descritti per as¬ 
semblare il vostro programma. 


PER TRASFERIRE il programma sull’ST6 

Dopo aver assemblato il programma ed aver ot¬ 
tenuto la scritta ***success***, potrete trasferirlo 
nella memoria del microprocessore ST6. 
















Quando siete nel menu principale dovrete: 
premere ALT+P 

e dopo pochi secondi comparirà l’intestazione del 
software delle SGS in lingua inglese. 

A questo punto, prendete la rivista N.172/173 (se 
non l’avete potrete sempre richiederla) poi rilegge¬ 
te quanto riportato nelle pagg.39-41, che non ri¬ 
scriviamo perché sarebbe un’inutile ripetizione di 
quanto abbiamo già spiegato. 

TRASFERIRE un FILE sul DISCHETTO 

Nel caso voleste trasferire un programma già as¬ 
semblato dall’Hard-Disk in un dischetto, ad esem¬ 
pio per darlo ad un amico, dovrete, sempre par¬ 
tendo dal menu principale: 

premere ALT+F 
poi premere D 

Apparirà la scritta C:\ST6> 

A questo punto inserite il dischetto nel drive, ed 
ammesso che abbiate chiamato il programma che 
volete trasferire DPLPROVA, dovrete scrivere que¬ 
sta istruzione: 

C:\ST6>Copy DPLPROVA.ASM A:\DPLPROVA.ASM 

poi Enter 

Quando apparirà la scritta 1 file copiato dovrete 
scrivere: 

C:\ST6>EXIT poi Enter 
TRASFERIRE dal FLOPPY all’HARD-DISK 

Per trasferire un programma dal dischetto all’Hard- 
Disk dovrete, quando vi trovate nel menu princi¬ 
pale: 

premere ALT+F 
poi premere D 

Apparirà la scritta C:\ST6> 

A questo punto inserite il dischetto nel drive, ed 
ammesso che il programma da trasferire si chiami 
DPLPROVA, dovrete scrivere questa istruzione: 

C:\ST6>Copy A:\DPLPROVA.ASM DPLPROVA.ASM 

poi Enter 

Quando comparirà la scritta 1 file copiato dovre¬ 
te scrivere: 

C:\ST6>EXIT poi Enter 


NOTA IMPORTANTE 

All’inizio di tutti i programmi che vi forniamo trove¬ 
rete questa istruzione: 

.ORG 880h 

che serve per i soli microprocessori ST6 con 2K di 
memoria, cioè i: 

ST62/E10 - ST62/E15 - ST62/T10 - ST62/T15 

Se utilizzerete dei microprocessori ST6 con 4K di 
memoria, cioè i: 

ST62/E20 - ST62/E25 - ST62/T20 - ST62/T25 

dovrete sostituire il numero 880h con il numero 
080h, quindi dovrete scrivere: 

ORG 080h 

Pertanto se usate un ST6 da 2K di memoria, do¬ 
vrete necessariamente scrivere all’inizio del pro¬ 
gramma 880h, perché se scriverete 080h, non ri¬ 
sultando presenti in questo ST6 queste celle di 
memoria, non riuscirete a trasferire nessun pro¬ 
gramma, ed il programmatore lo segnalerà. 

Se usate un ST6 da 4K di memoria dovrete scri¬ 
vere all’inizio del programma 080h per poter utiliz¬ 
zare tutta la sua memoria. 

Facciamo presente che se avete un programma da 
2K, che ovviamente inizierà con l’indirizzo di me¬ 
moria 880h, lo potrete tranquillamente trasferire 
con lo stesso indirizzo anche in un ST6 da 4K. 

In questo caso partendo dall’indirizzo 880h rimar¬ 
ranno inutilizzate tutte le celle di memoria da 080h 
a 87Fh. 


COSTO DI REALIZZAZIONE 

Tutti i componenti per realizzare la scheda Display 


siglata LX.1204 visibile nelle figg.6-7 completa di 
circuito stampato, integrato M.5450 e 4 
display.€ 18,60 

Tutti i componenti per realizzare la scheda Relè si¬ 
glata LX.1205 visibile nelle figg.9-10 completa di 
circuito stampato e 4 relè.€ 19,10 

Costo del solo stampato LX.1204.€ 4,34 

Costo del solo stampato LX.1205.€ 5,06 


Ai prezzi riportati andranno aggiunte le sole spese 
di spedizione a domicilio. 






Quando un lettore ci scrive che, montato un nostro 
progetto non riesce a farlo funzionare, presumia¬ 
mo che abbia commesso un errore, poiché prima 
di pubblicare nella rivista un qualsiasi circuito, è no¬ 
stra consuetudine farne montare una decina di e- 
semplari e se constatiamo che uno di questi risul¬ 
ta critico o presenta qualche anomalia lo ripor¬ 
tiamo in laboratorio per ricercarne le cause e per 
eliminarle. 

Questo modo di procedere lo adottiamo per ridur¬ 
re al minimo le riparazioni e per assicurare al let¬ 
tore il sicuro ed immediato funzionamento di ogni 
nostro progetto. 

A volte si verificano anche delle strane anomalie 
che fanno arrabbiare i lettori ed impazzire i tecni¬ 
ci della consulenza. 


per capire per quale motivo apparisse un simile er¬ 
rore, abbiamo chiesto a 2 lettori residenti a Ra¬ 
venna e a Ferrara se fossero disposti a venire a 
Bologna portando il loro computer, perchè vole¬ 
vamo cercare di scoprire la causa di questa ano¬ 
malia. 

Infatti se su 4.738 kit che funzionano in modo per¬ 
fetto solo 16 si rifiutano di farlo, il difetto può es¬ 
sere causato solo dal computer ed infatti grazie a 
questi 2 lettori siamo riusciti ad individuarlo. 
Abbiamo scoperto che nei loro computer il segna¬ 
le che entrava nel piedino 4 del CONN.1 (vedi nel¬ 
lo schema elettrico riportato a pag.31 della rivista 
N.172/173 il segnale D2 che, tramite la R7, giun¬ 
ge al piedino 1 della porta IC1/E) era strettissi¬ 
mo oppure aveva un’ampiezza ridotta. 


NOTA per il programmatore 


Se voi foste un tecnico che da anni usa questo pro¬ 
grammatore per ST6 senza mai riscontrare nes¬ 
sun inconveniente, che conosce tanti amici (esat¬ 
tamente 4.738) che lo hanno realizzato con suc¬ 
cesso, usandolo con diversi tipi di computer, e poi 
trovaste solo 16 lettori che si lamentano perchè il 
loro montaggio non funziona, cosa rispondereste 
loro ? 

Senz’altro che hanno commesso un errore nel 
montaggio, ed è questa anche la nostra risposta. 
Ciò che ci ha stupito è constatare che a tutti e 16 
questi lettori sul monitor appariva lo stesso mes¬ 
saggio, cioè: 

Target chip not present or detective! 

Subito abbiamo pensato che avessero acquistato 
dei microprocessori ST6 difettosi già all’origine. 
Per risolvere tale problema ci siamo fatti inviare 
questi ST6 insieme al programmatore per con¬ 
trollare entrambi in laboratorio. 

Appena arrivati, li abbiamo provati su 8 diversi com¬ 
puter e tutti gli ST6 che ci sono stati inviati si sono 
regolarmente programmati, senza errori. 

Rispediti i programmatori a questi lettori, tutti e 16 
ci hanno risposto che appariva nuovamente il me¬ 
desimo errore. 

Se non ci chiamassimo Nuova Elettronica, a que¬ 
sto punto avremmo abbandonato questi 16 lettori 
con i loro ST6 difettosi, ma per serietà ed anche 


Scartata l’idea di manomettere il computer, abbia¬ 
mo risolto il problema allargando l’impulso con un 
piccolo condensatore da 470 picoFarad ceramico 
posto tra la resistenza R7 e la massa come visibi¬ 
le nelle figg.1-2. 

Immediatamente abbiamo comunicato ai 16 letto¬ 
ri che non riuscivano a programmare gli ST6, di 
aggiungere sul loro programmatore questo con¬ 
densatore da 470 picoFarad e questi ci hanno ri¬ 
sposto che la scritta: 

Target chip not present or detective! 

non appare più e con questa semplice modifica o- 
ra riescono a programmare qualsiasi ST6. 

Importante = Se il vostro programmatore funzio¬ 
na correttamente non è necessario che inseriate 
questo condensatore, comunque se qualche volta 
vi capita di non riuscire a programmare un ST6, 
provate a collocare questo condensatore da 470 
pF tra la R7 e la massa ed il difetto sparirà. 

Come potete constatare, quando ci imbattiamo in 
qualche anomalia, facciamo tutto il possibile per 
eliminarla, ma se i due lettori di Ravenna e Ferra¬ 
ra non ci avessero portato il loro computer, forse 
questo caso sarebbe rientrato negli insoluti, per¬ 
chè nessuno poteva supporre che il segnale che 
usciva dalla loro presa parallela fosse fuori stan¬ 
dard. 



Fig.1 Se constatate che il vo¬ 
stro programmatore LX.1170 
non sempre riesce a pro¬ 
grammare un ST6, potrete ri¬ 
solvere questo problema col¬ 
legando tra il piedino 1 dell’in¬ 
tegrato IC1-E e la massa dello 
stampato, un condensatore 
da 470 picoFarad. 


LXil 170 per micro ST6 



Fig.2 Questo condensatore, collegato dopo la resistenza R7, serve per allargare quegli 
impulsi che giungono troppo stretti sull’Ingresso dell’inverter IC1-E. 



























































A pag.124 della rivista N.175/176 abbiamo riporta¬ 
to il programma N.15 che consente di accendere 5 
diodi led variando la tensione d’ingresso da 1 a 5 
volt. 

Molti lettori sulla base di questo esempio hanno u- 
tilizzato i micro ST62E15 o ST62E25, poi hanno 
cercato di modificare il programma per far accen¬ 
dere 8 diodi led e quando sono andati ad assem¬ 
blarlo, il computer ha segnalato questo errore: 

5-bit displacement overlow 

Con tale indicazione il microprocessore segnala 
che non può fare un salto all’etichetta richiesta 
perchè sono troppe le righe che lo separano da es¬ 
sa. 

Nel nostro esempio avevamo usato soltanto 5 dio¬ 
di led, quindi utilizzando degli altri diodi led si so¬ 


no dovute aggiungere delle altre righe di program¬ 
ma e poiché le istruzioni JRC - JRNC - JRZ - JRNZ 
possono fare solo dei salti limitati ad un certo nu¬ 
mero di righe, se queste sono maggiori del richie¬ 
sto appare il messaggio di errore menzionato. 

In presenza di salti molto lunghi è necessario mo¬ 
dificare l’istruzione presente con quella inversa, 
poi scrivere nella riga successiva l’istruzione JP 
che è in grado di fare un salto in qualsiasi punto 
del programma anche se molto distante. 

Le istruzioni andranno quindi modificate: 

da JRC a JRNC 
da JRNC a JRC 
da JRZ a JRNZ 
da JRNZ a JRZ 


PROGRAMMA per Esempio n.15 

LDI pdir_a,00000000B 

LDI popt_a,10000000B 

LDI port_a,10000000B 

in queste tre righe abbiamo settato 
il piedino A7 come ingresso analogico 

LDI pdir b,00011111B 

LDI popt b,00011111B 

LDI port_b,00000000B 

in queste righe abbiamo settato 
i piedini da BO a B4 come uscite 

ripeti LDI wdog,255 

carichiamo il watchdog 

LDI adcr,00110000B 

provvedi a convertire da analogico a digitale 

attendi JRR 6,adcr,attendi 

attendere che avvenga la conversione A/D 

LD a,addr 

carica nell’accumulatore A, il numero digitale 

CPI a, 255 

compara il valore di A con il numero 255 

JRNC LED5 

se A è uguale a 255 salta all’etichetta LED5 

CPI a,204 

compara il valore di A con il numero 204 

JRNC LED4 

se A è maggiore di 204 salta all’etichetta LED4 

CPI a,153 

compara il valore di A con il numero 153 

JRNC LED3 

se A è maggiore di 153 salta all’etichetta LED3 

CPI a,102 

compara il valore di A con il numero 102 

JRNC LED2 

se A è maggiore di 102 salta all’etichetta LED2 

CPI a, 51 

compara il valore di A con il numero 51 

JRNC LEDI 

se A è maggiore di 51 salta all’etichetta LEDI 

JP LEDO 

se A è minore di 51 salta all’etichetta LEDO 

LEDO LDI port_b,00000000B 

non accendere nessun diodo led 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LEDI LDI port_b,00000001B 

accendi il led sul piedino BO 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED2 LDI port_b,00000011B 

accendi i led sui piedini BO - B1 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED3 LDI port_b,00000111B 

accendi i led sui piedini BO - B1 - B2 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED4 LDI port_b,00001111B 

accendi i led sui piedini BO - B1 - B2 - B3 

JP ripeti 

salta all’etichetta ripeti del watchdog 

LED5 LDI port_b,00011111B 

accendi i led sui piedini BO - B1 - B2 - B3 - B4 

JP ripeti 

salta all’etichetta ripeti del watchdog 





PROGRAMMA SALTO Esempio n. 15 bis 



LDI 

pdir_a,00000000B 

in queste tre righe abbiamo settato 


LDI 

popt_a,10000000B 

il piedino A7 come ingresso analogico 


LDI 

port_a,10000000B 



LDI 

pdir b,11111111B 

in queste righe abbiamo settato 


LDI 

popt_b,11111111B 

i piedini della porta B come uscite 


LDI 

port_b,00000000B 


ripeti 

LDI 

wdog,255 

carichiamo il watchdog 


LDI 

adcr,00110000B 

provvedi a convertire da analogico a digitale 

attendi 

JRR 

6, adcr, attendi 

attendere che avvenga la conversione A/D 


LD 

a,addr 

carica nell’accumulatore A il numero digitale 


CPI 

a,255 

compara il valore di A con 255 


JRC 

etichi 

se A è minore di 255 salta a etichi 


JP 

LED8 

salta a LED8 

etichi 

CPI 

a,224 

compara il valore di A con 224 


JRC 

etich2 

se A è minore di 224 salta a etich2 


JP 

LED7 

salta a LED7 

etich2 

CPI 

a,192 

compare il valore di A con 192 


JRC 

etich3 

se A è minore di 192 salta a etich3 


JP 

LED6 

salta a LED6 

etich3 

CPI 

a,160 

compara il valore di A con 160 


JRC 

etich4 

se A è minore di 160 salta a etich4 


JP 

LED5 

salta a LED5 

etich4 

CPI 

a,128 

compara il valore di A con 128 


JRC 

etich5 

se A è minore di 128 salta a etich5 


JP 

LED4 

salta a LED4 

etich5 

CPI 

a,96 

compara il valore di A con 96 


JRC 

etich6 

se A è minore di 96 salta a etich6 


JP 

LED3 

salta a LED3 

etich6 

CPI 

a,64 

compara il valore di A con 64 


JRC 

etich7 

se A è minore di 64 salta a etich7 


JP 

LED2 

salta a LED2 

etich7 

CPI 

a,32 

compara il valore di A con 32 


JRC 

etich8 

se A è minore di 32 salta a etich8 


JP 

LEDI 

salta a LEDI 

etich8 

JP 

LEDO 

salta a LEDO 

LEDO 

LDI 

port_b,OOOOOOOOB 

non accendere nessun diodo led 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LEDI 

LDI 

port_b,00000001B 

accendi il led sul piedino BO 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED2 

LDI 

port_b,00000011B 

accende i led sui piedini BO - B1 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED3 

LDI 

port_b,00000111B 

accende i led sui piedini BO - B1 - B2 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED4 

LDI 

port_b,00001111B 

accende i led sui piedini BO - B1 - B2 - B3 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED5 

LDI 

port_b,00011111B 

accende i led sui piedini BO - B1 - B2 - B3 - B4 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED6 

LDI 

port-b, 00111111B 

accende i led sui piedini da BO a B5 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED7 

LDI 

port-b,01111111B 

accende i led sui piedini da BO a B6 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 

LED8 

LDI 

port-b,11111111B 

accende i led sui piedini da BO a B7 


JP 

ripeti 

salta all’etichetta ripeti del watchdog 




Nel programma presentato a pag.124 come “E- 
sempio N.15” abbiamo scritto nella 12° riga que¬ 
sta istruzione: 

JRNC LED5 ; se A è uguale a 255 salta all’eti¬ 
chetta LED5 

Nel caso in cui si desiderino aggiungere degli altri 
led, sarà necessario modificare il programma co¬ 
me segue: 

JRC etichi ; se A è minore di 255 salta a etichi 
JP LED8; salta a LED8 

Etichi; etichetta 1 che proseguirà con il pro¬ 
gramma 

Se ancora tutto questo non vi risulta chiaro, con¬ 
frontate il primo programma Esempio N.15 con il 
secondo programma modificato, che abbiamo chia¬ 
mato Esempio N.15 BIS. 


CONVERTITORE A/D 

Nella rivista N.175/176 a pag.123 abbiamo scritto 
che, risultando presente all’Interno dell’ST6 un so¬ 


lo A/D converter, potevamo utilizzare come in¬ 
gresso per segnali analogici un solo piedino. 

In pratica è possibile utilizzare anche più piedini 
come ingressi analogici, sempre che si scriva un 
programma che vada a leggere in multiplexer le 
tensioni presenti su tutti i piedini d’ingresso che ab¬ 
biamo prescelto per questa funzione. 

Per farvi comprendere come un solo A/D conver¬ 
ter possa leggere le tensioni poste su diversi pie¬ 
dini, vi proponiamo qui di seguito un esempio. 
Ammesso di possedere un solo voltmetro e di vo¬ 
ler leggere con questo valori di tensione presenti 
su punti diversi, potremo farlo se sull’ingresso del 
voltmetro applicheremo il cursore di un commu¬ 
tatore rotativo e sui terminali di commutazione le 
diverse tensioni che vorremo leggere. 

Ruotando il commutatore sulle diverse posizioni, 
potremo leggere più tensioni pur disponendo di 
un solo voltmetro. 

Vogliamo comunque ricordarvi che come ingressi 
analogici potremo usare qualsiasi piedino ad ec¬ 
cezione dei soli piedini A0-A1-A2-A3. 

Nel programma che qui riportiamo come Pro¬ 
gramma A/D vi facciamo vedere come bisognerà 
scrivere le istruzioni per poter leggere le tensioni 
presenti sui piedini d’ingresso di B5-B6-B7. 


PROGRAMMA A/D 


LDI 

pdir_b,00000000B 

nelle prime cinque righe 

LDI 

popt_b,00000000B 

abbiamo settato il piedino B7 

LDI 

port_b,00000000B 

come ingresso analogico 

LDI 

port_b,10000000B 


LDI 

popt b,10000000B 


LDI 

adcr,00110000B 

provvedi a convertire da analogico a digitale 

JRR 

6,adcr,AD1 

attendere che avvenga la conversione A/D 

LD 

a,ADDR 

copia in A il valore dell’A/D 

LD 

VOLTI,a 

copia in VOLTI il valore di a 

LDI 

pdir_b,00000000B 

nelle prime cinque righe 

LDI 

popt_b,00000000B 

abbiamo settato il piedino B6 

LDI 

port_b,00000000B 

come ingresso analogico 

LDI 

port_b,01000000B 


LDI 

popt_b,01000000B 


LDI 

adcr, 00110000B 

provvedi a convertire da analogico a digitale 

JRR 

6,adcr,AD2 

attendere che avvenga la conversione A/D 

LD 

a,ADDR 

copia in A il valore dell’A/D 

LD 

VOLT2,a 

copia in VOLT2 il valore di a 

LDI 

pdir_b,00000000B 

nelle prime cinque righe 

LDI 

popt_b,00000000B 

abbiamo settato il piedino B5 

LDI 

port_b,00000000B 

come ingresso analogico 

LDI 

port_b,00100000B 


LDI 

popt_b,00100000B 


LDI 

adcr,00110000B 

provvedi a convertire da analogico a digitale 

JRR 

6,adcr,AD3 

attendere che avvenga la conversione A/D 

LD 

a.ADDR 

copia in A il valore dell’A/D 

LD 

VOLT3,a 

copia in VOLT3 il valore di a 




Se avete già acquistato il kit per testare gli ST6 si¬ 
glato LX.1202 e le due schede, una con quattro di¬ 
splay siglata LX.1204 e l’altra con quattro relè si¬ 
glata LX.1205 pubblicate nella rivista N.179, avre¬ 
te ricevuto anche un dischetto con codice 
DF.1202/3 = DF.1170/3 contenente diversi pro¬ 
grammi formato “.ASM” che, caricati nell’hard-disk, 
vi serviranno per gestire le due schede sperimen¬ 
tali apparse nella rivista N.179 e quella che appa¬ 
re su questo numero con quattro triac siglata 
LX.1206. 

Prossimamente vi forniremo altre due schede per 
display LCD alfanumerici ed altri nuovi program¬ 
mi. 

Anche se lo abbiamo già precisato negli articoli pre¬ 
cedenti, vi ricordiamo che i programmi .ASM li po¬ 
trete trasferire singolarmente nella memoria di un 
microprocessore ST6 solo dopo averli assembla¬ 
ti, cioè convertiti in files formato .HEX. 


I tre programmi CONTA-LED-LOTTO che sono as¬ 
semblati in .HEX sono già pronti per essere cari¬ 
cati all’interno della memoria dell’ST6. 

Tutti gli altri programmi che terminano con .ASM li 
potrete tranquillamente modificare, ampliare e, co¬ 
me già accennato, prima di passarli nella memoria 
di un ST6 li dovrete assemblare per convertirli in 
files .HEX. 

Le modifiche in questi programmi sono sempre ne¬ 
cessarie per adattarli alle vostre esigenze. Ad e- 
sempio, noi abbiamo predisposto i programmi Tl- 
MER.ASM e TEMPOR.ASM per eccitare un relè o 
un Triac in un tempo di 3 minuti sia contando all’in- 
dietro (TEMPOR.ASM) che in avanti (TIMER.ASM) 
e poiché questo tempo non vi servirà per nessuna 
delle vostre applicazioni, basterà leggere all’inter¬ 
no del programma i vari commenti per sapere qua¬ 
le riga dovrete correggere e quale numero inse- 


SCI 


A con 4 

n 

RI 

IAC 


Nel dischetto DF.1202/3 identico al DF.1170/3 che 
da oggi forniamo, troverete questi 18 programmi: 


1 A CONTA.ASM 
2* LED.ASM 
3 A LOTTO.ASM 
4 A STANDARD.ASM 

5 A CRONOMET.ASM 
6 A DISPLAY.ASM 
7 A LM093.ASM 
8 A OROLOGIO.ASM 
9 A RELE.ASM 
10 A TEMPOR.ASM 
11 A TIMER.ASM 
12 A TRI AC. ASM 
13 A CLOCK.ASM 
14 A TIME90.ASM 
15 A TEMP90.ASM 

16 A CONTA.HEX 
17 A LED.HEX 
18 A LOTTO.HEX 


Nota = I primi 4 programmi ve li avevamo già for¬ 
niti con il primo disco floppy assieme al program¬ 
matore per ST6 (vedi rivista n.172-173). 


rire per modificarla. 

Anche in tutti gli altri programmi troverete di lato ad 
ogni riga un commento che vi spiegherà se pote¬ 
te modificarla, sostituirla, o cancellarla. 

Le modifiche non fatele mai sul nostro file, ma su 
un identico file che duplicherete attribuendogli un 
nome diverso, in modo da avere sempre a dispo¬ 
sizione il file originale per poterlo consultare o con¬ 
frontare per scoprire eventuali errori sui files modi¬ 
ficati. 

Tutte le istruzioni richieste per poter duplicare un 
file le troverete in questo articolo. 

Non dovrete mai modificare i programmi presen¬ 
ti all’interno del dischetto che terminano con BAT 
- EXE - COM - DEV - HEX. 

Sul disco che vi forniremo, oltre ai programmi .A- 
SM, è presente anche un EDITOR che vi servirà 
per scrivere dei programmi e per ASSEMBLARE i 
files prima di caricarli sui microprocessori ST6 tra¬ 
mite il programmatore LX.1170 (leggere la rivista 
N.172-173). 

Una volta comprese le funzioni dei vari blocchi, 
potrete ampliarli, modificarli oppure trasferirli su 

un vostro programma per poter gestire, secondo la 
vostra fantasia, queste ed altre schede speri¬ 
mentali. 






Sul precedente numero della rivista vi abbiamo presentato due schede 
per ST6, una per accendere dei normali display a 7 segmenti ed un’al¬ 
tra per eccitare dei relè. In questo numero vi presentiamo una scheda 
per eccitare quattro diodi Triac, spiegandovi anche come si possono 
modificare i programmi da noi forniti. 


UN PROMEMORIA 

Anche se nel numero 179 della rivista abbiamo 
spiegato che occorre necessariamente inserire 
queste schede sperimentali nel bus siglato 
LX.1202, molti ci chiedono se e su quale tipo di 
computer occorra collegarle e se per le prove con¬ 
venga usare un ST6 cancellabile o non cancel¬ 
labile. 

- La scheda bus siglata LX.1202 risulta progettata 
per ricevere tutte le schede sperimentali che vi ab¬ 
biamo presentato e anche le future con display 
LCD. Questa scheda non andrà collegata a nes¬ 
sun computer, ma serve per inserirvi l’ST6 che ab¬ 
biamo programmato. 

- Oltre alla scheda bus vi servirà anche il Pro¬ 
grammatore per micro ST6 siglato LX.1170 pub¬ 


blicato nella rivista N.172/173, che sarà indispen¬ 
sabile per poter trasferire il programma che sce¬ 
glierete o che avrete scritto dal computer alla me¬ 
moria del microprocessore ST6. 

Dopo aver trasferito il programma nel microproces¬ 
sore, dovrete togliere quest’ultimo dallo zoccolo Tex- 
tool del programmatore LX.1170 ed inserirlo nella 
scheda bus siglata LX.1202 per poter gestire le sche¬ 
de sperimentali che applicherete su questo bus. 

Vi ricordiamo che il solo programmatore LX.1170 
andrà collegato alla porta parallela del vostro com¬ 
puter, purché questo sia un IBM o un compatibi¬ 
le serie XT - AT - SX - DX tipo 8088 - 286 - 386 - 
486 - Pentium con qualsiasi frequenza di clock, 
compresi anche i portatili con installato il sistema 
operativo DOS dal 3 al 6.2. 

Ripetiamo nuovamente che il software per ST6 
non è assolutamente compatibile per computer ti¬ 
po Commodore, Apple, Amiga, ecc. 







Fig.1 Per duplicare il programma STAN- 
DARD.ASM dovrete prima richiamare l’Edi- 
tor, scrivendo C:\>ST6 poi Enter. Dopodi¬ 
ché scriverete C:\ST6>ST6 e a questo pun¬ 
to potrete premere il tasto Enter. 



Fig.2 Premete i tasti ALT F poi F3 e, così fa¬ 
cendo, vi appariranno tutti i files ASM. Por¬ 
tate il cursore sulla riga STANDARD.ASM, 
premete Enter e, in tal modo, vi apparirà la 
finestra di fig.3. 



Fig.3 Portate il cursore sulla riga SAVE as 
... poi premete Enter. Per duplicare questo 
file con un nome “diverso” ripremete i due 
tasti ALT F e, in tal modo, vi apparirà la fi¬ 
nestra di fig.4. 


- Per le prove sperimentali conviene scegliere un 
microprocessore tipo ST62E20 con 4 K di Rom (il 
micro ST62E10 è stato messo fuori produzione dal¬ 
la SGS), perchè, anche se risulta molto costoso, 
lo potrete cancellare e riutilizzare diverse centinaia 
di volte per memorizzare degli altri nuovi e diver¬ 
si programmi. 

- Per cancellare uno di questi microprocessori po¬ 
trete usare la lampada ad ultravioletti siglata 
LX.1183 presentata sulla rivista N.174. 

- Se volete usare i più economici microprocessori 
tipo ST62T10 o ST62T20 potete farlo, ma poiché 
questi non sono cancellabili, se sbaglierete nel¬ 
lo scrivere un programma, dovrete buttarli ed ac¬ 
quistarne degli altri. 

Normalmente i microprocessori non cancellabili 
vengono utilizzati solo dopo aver testato più di u- 
na volta il micro cancellabile tipo ST62E20, per a- 
vere la certezza che nel vostro programma non 
vi siano degli errori. 


TABELLA N.1 micro NON CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62T.10 

2 K 

64 byte 

20 pin 

12 

ST62T.15 

2 K 

64 byte 

28 pin 

20 

ST62T.20 

4 K 

64 byte 

20 pin 

12 

ST62T.25 

4 K 

64 byte 

28 pin 

20 


TABELLA N.2 micro CANCELLABILI 


Sigla 

Micro 

memoria 

utile 

Ram 

utile 

zoccolo 

piedini 

piedini utili 
per i segnali 

ST62E.20 

4 K 

64 byte 

20 pin 

12 

ST62E.25 

4 K 

64 byte 

28 pin 

20 


- Quando vorrete scrivere dei nuovi programmi do¬ 
vrete sempre caricare il file STANDARD.ASM, per¬ 
chè questo è il file sorgente che definisce la loca¬ 
zione dei 5 registri del micro e fa il settaggio del¬ 
le periferiche, cioè una inizializzazione completa. 


IL SORGENTE STANDARD.ASM 

Ritenevamo di aver spiegato abbastanza bene a 
cosa serva il file STANDARD.ASM, ma leggendo 
i quesiti che ci sono pervenuti in proposito abbia¬ 
mo capito di non essere stati sufficientemente e- 
saurienti. 

























































Per riparare, ve lo rispiegheremo proponendovi an¬ 
che qualche esempio. 

Quando si scrive un programma, occorre sempre 
iniziare con dei dati ripetitivi che non varino mai 
da un programma ad un altro, quindi per non ri¬ 
scriverli ogni volta con il rischio di commettere de¬ 
gli errori, ve li ritroverete già tutti impostati nel pro¬ 
gramma STANDARD.ASM con una nota relativa 
a cosa dovrete modificare. 

Ad esempio, quando arriverete al paragrafo SET¬ 
TAGGIO INIZIALE, subito dopo INIZIO PRO¬ 
GRAMMA troverete tra le prime righe l’istruzione: 

.org 0880h 

Se usate un micro da 2K di memoria, cioè un 

ST62E10 - ST62T10 - ST62E15 - ST62T15, non 
dovrete modificare questo numero. 

Se usate un micro da 4K, cioè un ST62E20 - 
ST62T20 - ST62E25 - ST62T25, dovrete invece 
modificare questo numero come segue: 

.org 080h 

Ammettiamo ad esempio di voler creare un nuovo 
programma chiamato ALIBABA. 

La prima operazione da effettuare sarà quella di u- 
scire da qualsiasi programma in utilizzo, come ad 
esempio Windows, Pcshell, Norton, ecc., in mo¬ 
do da vedere in alto a sinistra del vostro schermo 
il solo Prompt dei comandi, cioè C:\> 

A questo punto potrete richiamare il programma 
ST6 scrivendolo indifferentemente sia in maiusco¬ 
lo che in minuscolo: 

C:\>CD ST6 poi premete Enter 

e in questo modo vi apparirà: 

C:\ST6> 

poi scrivete ST6 come sotto riportato: 

C:\ST6>ST6 poi premete Enter 

e subito vedrete apparire sul monitor del computer 
la finestra dell’EDITOR (vedi fig.1). 

A questo punto premete contemporaneamente i ta¬ 
sti ALT F, poi F3 e vi apparirà una seconda fine¬ 
stra con gli elenchi di tutti i files .ASM (vedi fig.2). 
Premete il tasto Enter e vedrete che il cursore an¬ 
drà sul primo file .ASM colorandolo di verde. 

Utilizzando i tasti freccia presenti sulla tastiera, 
portate il cursore sulla riga STANDARD.ASM, poi 
premete Enter e vedrete apparire sul monitor il li- 



Fig.4 Per cambiare il nome del file STAN¬ 
DARD.ASM con ALIBABA dovrete scrivere 
C:\ST6\ALIBABA.ASM e poi premere ALT 
F3. Se desiderate cambiare il listato del file 
TIMER dovrete scrivere C:\ST6\TIMER.ASM. 



Fig.5 In tutti i listati troverete di lato un 
“commento condensato” che vi aiuterà a 
capire quale funzione esplicano le varie ri¬ 
ghe. Con un po’ di esperienza riuscerete 
molto facilmente a modificarle. 



Fig.6 Corretto o riscritto, dovrete “salvare” 
il nuovo programma premendo il tasto F2, 
dopodiché lo potrete ASSEMBLARE pre¬ 
mendo i tasti ALT T poi A. Se non avete 
commesso “errori” apparirà SUCCESS. 



























































stato di questo programma che potrete leggere 
dall’inizio fino alla fine. 

A questo punto se premerete contemporaneamen¬ 
te i due tasti ALT F vedrete apparire una nuova 
maschera (vedi fig.3). 

Con il tasto freccia giù andate alla riga dove è scrit¬ 
to: 

SAVE as.... poi premete Enter 

Così facendo vi apparirà una riga con scritto: 

C:\ST6\STANDARD.ASM 

Poiché intendiamo chiamare il nuovo programma 
ALIBABA, questa riga la dovrete riscrivere come 
segue: 

C:\ST6\ALIBABA.ASM poi premete Enter 

Nota = I nomi dei files non debbono mai avere più 
di 8 caratteri escluso ovviamente .ASM 
Corretta questa riga, premete i tasti ALT F3 e vi 
apparirà nuovamente la maschera dell’EDITOR. 

A questo punto dovrete premere i due tasti ALT F, 
poi F3 e nella lista dei files troverete il nuovo file 
denominato ALIBABA.ASM. 

Dopo aver premuto Enter, con i tasti delle frecce 
portate il cursore sul file ALIBABA.ASM e, in que¬ 
sto modo, vi apparirà il listato duplicato del file 
STANDARD.ASM, che potrete tranquillamente 
modificare perchè ora lavorerete sul file ALIBA- 
BA.ASM. 

Se, per ipotesi, tutte le modifiche che apporterete 
sul file ALIBABA.ASM non lo faranno funzionare 
per qualche errore da voi commesso, lo potrete 
cancellare e nuovamente ricopiare, utilizzando il 
file originale STANDARD.ASM come vi abbiamo 
appena spiegato. 

Nel programma che in precedenza si chiamava 
STANDARD.ASM e che ora avete chiamato ALI- 
BABA.ASM dovrete ricordarvi che la riga: 

.org 0880h 

non va modificata se userete dei micro con 2K di 
memoria, vale a dire se userete degli ST62E10, 
ST62E15, ST62T10, ST62T15. 

Se invece userete dei micro con 4K, vale dire de¬ 
gli ST62E20, ST62E25, ST62T20, ST62T25, que¬ 
sta riga va modificata come segue: 

.org 080h 

A questo punto dovrete modificare il settaggio di 
tutte le porte A-B-C, cioè dovrete impostarle come 


ELENCO COMPONENTI LX.1206 

RI = 1.000 ohm 1/4 watt 
R2 = 100 ohm 1/4 watt 
R3 = 1.000 ohm 1/4 watt 
R4 = 100 ohm 1/4 watt 
R5 = 1.000 ohm 1/4 watt 
R6 = 100 ohm 1/4 watt 
R7 = 1.000 ohm 1/4 watt 
R8 = 100 ohm 1/4 watt 
R9 = 220 ohm 1/4 watt 
RIO = 220 ohm 1/4 watt 
RII = 220 ohm 1/4 watt 
RI 2 = 220 ohm 1/4 watt 
RI 3 = 10.000 ohm 1/4 watt 
RI4 = 10.000 ohm 1/4 watt 
RI5 = 10.000 ohm 1/4 watt 
RI 6 = 10.000 ohm 1/4 watt 
CI = 47.000 pF poi. 400 V. 

C2 = 47.000 pF poi. 400 V. 

C3 = 47.000 pF poi. 400 V. 

C4 = 47.000 pF poi. 400 V. 

C5 = 100.000 pF poliestere 
C6 = 100.000 pF poliestere 
C7 = 100.000 pF poliestere 
C8 = 100.000 pF poliestere 
TRC1 = triac tipo 500 V. 5 A. 
TRC2 = triac tipo 500 V. 5 A. 
TRC3 = triac tipo 500 V. 5 A. 
TRC4 = triac tipo 500 V. 5 A. 
OC1 = fototriac tipo MOC.3020 
OC2 = fototriac tipo MOC.3020 
OC3 = fototriac tipo MOC.3020 
OC4 = fototriac tipo MOC.3020 
PI = pulsante 
P2 = pulsante 
P3 = pulsante 
P4 = pulsante 


ingressi o uscite a seconda delle esigenze del vo¬ 
stro programma. 

Nel caso non sappiate come si faccia a settare le 
porte, vi consigliamo di leggere l’articolo “Impara¬ 
re a programmare i microprocessori ST6” pub¬ 
blicato nella rivista n. 175-176. 

Terminate tutte le modifiche e scritto il nuovo pro¬ 
gramma che si chiama ALIBABA.ASM, lo dovre¬ 
te salvare premendo il tasto F2. 

Ricordatevi di premere il tasto funzione F2 tutte le 



volte che eseguirete una variazione o farete un’ag¬ 
giunta nel programma, diversamente queste non 
verranno memorizzate. 

Una volta memorizzato, lo dovrete anche assem¬ 
blare premendo i tasti: 

ALT T poi il tasto A (vedi fig.6) 

Se non avrete commesso degli errori nello scrive¬ 
re un’istruzione, sul monitor vi apparirà la scritta: 

***success*** 


Se, in sostituzione di questa scritta, vi apparirà un 
numero in basso a sinistra sul monitor, significa 
che nella riga del programma che avete modifica¬ 
to o variato avete commesso un errore, ad esem¬ 
pio avete scritto Ip anziché Id. 

Un errore che molti commettono è quello di cari¬ 
care direttamente nel registro Y il contenuto del 
registro X scrivendo: 

id y,x 










































































Per caricare il contenuto del registro X nel registro 
Y dovrete prima caricare il registro X nell’accumu¬ 
latore A, poi caricare su questo il registro Y, quin¬ 
di questa istruzione andrà scritta su due righe: 

Id a,x 

Id y,a 

Tutti i files una volta assemblati diventeranno dei 
.HEX, cioè convertiti in esadecimale, perchè que¬ 
sto è il solo linguaggio che il microprocessore è in 
grado di interpretare. 

Vi ricordiamo che i files .HEX non potranno più es¬ 
sere modificati. 


SCHEMA ELETTRICO 

Lo schema elettrico di questa scheda per Triac è 
visibile in fig.7. 

In teoria, potevamo sfruttare tutte le porte A-B-C 
del microprocessore ST6 come uscite ed in tal mo¬ 
do potevamo inserire in questa scheda ben 20 
Triac con il micro da 28 piedini e 12 Triac con il 
micro da 20 piedini. 

In pratica, non potremo mai farlo, perchè dobbia¬ 
mo tenere impegnate diverse porte A e B per ge¬ 
stire anche le altre schede che inseriremo nel bus 
assieme alla scheda Triac o Relè. 

Quando sui piedini della porta B siglati B4-B5-B6- 
B7 (vedi fig.7) apparirà un livello logico 1, vale a 
dire una tensione positiva, questa polarizzerà il 
diodo emittente presente aH’interno dei fotoac¬ 
coppiatori siglati OC1-OC2-OC3-OC4 e di conse¬ 
guenza si ecciterà il Triac ad essi collegato. 
Questi quattro fotoaccoppiatori li abbiamo utiliz¬ 
zati per separare elettricamente l’uscita del micro- 
processore dalla tensione che applicheremo sul¬ 
le due boccole visibili a destra indicate con la scrit¬ 
ta Entrata Tensione Alternata. 

Per alimentare i Triac potremo usare qualsiasi ten¬ 
sione alternata partendo da un minimo di 4,5 volt 
per arrivare ad un massimo di 220 volt. 
Ovviamente sulle morsettiere indicate uscita 1 - 
uscita 2 - uscita 3 - uscita 4 dovremo applicare 
delle lampadine, dei motorini in alternata, o qual¬ 
siasi altra apparecchiatura elettrica che funzioni 
con il valore di tensione utilizzata per alimentare i 
Triac. 

Non utilizzate una tensione continua per alimen¬ 
tare i Triac. Se volete usare una tensione conti¬ 
nua dovrete necessariamente servirvi della sche¬ 
da RELÈ siglata LX.1205 presentata nella rivista 
N.179. 


REALIZZAZIONE PRATICA 

Sul circuito stampato siglato LX.1206 dovrete mon¬ 
tare tutti i componenti visibili in fig.8. 

Per il montaggio vi consigliamo di saldare sul la¬ 
to opposto di questo stampato il connettore ma¬ 
schio a 1 fila provvisto di 24 terminali (vedi 
CONN 1-2) e vicino alle due morsettiere Uscita 1 
e Uscita 4 i due connettori a 1 fila provvisti di so¬ 
li 4 terminali, che vi serviranno per innestare i 
connettori femmina presenti sulla scheda bus 
siglata LX.1202. 

Nella parte di stampato visibile in fig.8 inserirete i 
quattro zoccoli per i fotoaccoppiatori, tutte le re¬ 
sistenze, poi condensatori e le 5 morsettiere a 
due poli. 

Proseguendo nel montaggio, inserirete i 4 Triac si¬ 
glati TRC1-TRC2-TRC3-TRC4, rivolgendo la parte 
metallica del loro corpo verso destra come visibi¬ 
le nello schema pratico di fig.8. 

Completata questa operazione, potrete inserire ne¬ 
gli zoccoli i quattro fotoaccoppiatori rivolgendo 
verso sinistra il lato del loro corpo provvisto del 
piccolo foro di riferimento. 


INSERIMENTO SCHEDA nel BUS 

Questa scheda la potrete inserire nel bus siglato 
LX.1202, indifferentemente su un qualsiasi con¬ 
nettore femmina presente su questo stampato e lo 
stesso dicasi per la scheda dei display che utiliz¬ 
zerete per visualizzare i relativi tempi. 

Sulle morsettiere di destra indicate Entrata Ten¬ 
sione Alternata dovrete applicare la tensione che 
servirà per alimentare i motorini o le lampade che 
applicherete sulle quattro morsettiere d’uscita. 
Per le prime prove vi consigliamo di utilizzare una 
tensione alternata di 14 volt fornita dall’apposito 
alimentatore LX.1203, presentato sulla rivista 
N.179, collegando alle uscite dei Triac delle nor¬ 
mali lampadine da 12 volt massimo 3 watt. 

Se lo ritenete opportuno potrete anche entrare nel¬ 
la morsettiera di destra con una tensione alterna¬ 
ta di 220 volt collegando all’uscita dei Triac delle 
lampadine da 220 volt, ma attenzione, se usere¬ 
te la tensione di rete ricordatevi di non toccare mai 
le parti metalliche dei Triac e le uscite dei fotoac¬ 
coppiatori per evitare che la tensione dei 220 volt 
si scarichi sul vostro corpo. 

Con questa scheda potrete utilizzare tutti i pro¬ 
grammi che abbiamo usato per la scheda RELÈ 
siglata LX.1025. A fine articolo abbiamo ripor¬ 
tato come si possono modificare i tempi e le fun¬ 
zioni. 



Fig.8 Schema pratico di montaggio della scheda LX.1206. Il circuito stampato che vi for¬ 
niremo è un “doppia faccia” con fori metallizzati, quindi non cercate mai di allargare que¬ 
sti fori con una punta da trapano perchè, così facendo, asportereste il sottile strato di ra¬ 
me applicato per via galvanica al loro interno e che è necessario per collegare le piste 
presenti sotto al circuito stampato con quelle presenti sopra. 



Fig.9 Foto della scheda LX.1206 come si presenterà a montaggio ultimato. Questa sche¬ 
da andrà posta sul Bus siglato LX.1202 (vedi fig.10) assieme al microprocessore ST6 che 
avrete già programmato con uno dei programmi necessari per gestirlo. Consigliamo di ri¬ 
leggere le riviste N.172/173 - 174 - N.175/176 - N.179 per sapere come si deve procede¬ 
re per memorizzare un micro e per settare tutte le PORTE. 































































INSTALLAZIONE programmi nell’HARD-DISK 

Riportiamo in forma condensata quanto già scritto 
nelle riviste numero 172/173 -174 -175/176 -179, 
perchè ad alcuni lettori potrebbe essere sfuggito u- 
no o più di questi numeri in cui sono apparsi i se¬ 
guenti articoli: 

Programmatore per micro ST6 
Circuito test per microprocessore ST62E10 
Impariamo a programmare i micro ST6 
Lampada per cancellare Eprom 
Impariamo a programmare i micro ST6 
Bus per testare i micro ST6 
Scheda test per Relè 
Scheda test per display 

Facciamo presente che sono ancora reperibili pres¬ 
so la nostra Sede alcune centinaia di copie delle 
riviste sopra elencate, quindi chi ne fosse sprovvi¬ 
sto e volesse avere la serie completa di articoli i- 
nerenti il microprocessore ST6, potrà richieder¬ 
cele fino al loro esaurimento. 


Per copiare il dischetto relativo all’ST6 nell’Hard- 
Disk di un computer dovrete procedere come se¬ 
gue: 

1 - Uscite da qualsiasi programma tipo Windows 
- Pcshell - Norton, ecc. 

2 - Quando sul monitor apparirà il prompt C:\>, in¬ 
serite nel drive floppy A il dischetto contenente i 
programmi, poi digitate: 

C:\>A: poi premete il tasto Enter 

e vi apparirà A:\> 

A questo punto potrete scrivere: 

A:\>installa poi premete Enter 

Subito vi apparirà sul monitor la richiesta su quale 
directory volete installare il contenuto del disco. 
La directory da noi predefinita è ST6, quindi se di¬ 
giterete Enter (vedi fig.11) il programma creerà u- 



Fig.10 A quanti desiderano se¬ 
guire questo corso sugli ST6 con¬ 
sigliamo di procurarsi il kit 
LX.1170 che servirà per trasferire 
i programmi che abbiamo as¬ 
semblato da .ASM in .HEX, più il 
BUS siglato LX.1202 completo 
del suo alimentatore LX.1203. 
Questo BUS LX.1202 servirà, 
prossimamente, per controllare 
la scheda con un display LCD nu¬ 
merico e la scheda con un display 
LCD alfanumerico. 


















na directory con questo nome e copierà nell’Hard- 
Disk tutto il contenuto del dischetto scompattan¬ 
do i files. 

Se volete trasferire il contenuto su una diversa di¬ 
rectory, ad esempio LX1202, quando sul monitor 
vi apparirà: 

C:\ST6 

dovrete cancellare il nome della directory prece¬ 
dente, cioè ST6 (vedi fig.11), scrivendo in sua so¬ 
stituzione LX1202 come qui sotto riportato: 

C:\LX1202 poi premete Enter 

Ricordatevi che qualsiasi nome di directory sce¬ 
glierete non dovrete mai superare gli 8 caratteri e 
nemmeno utilizzare dei caratteri che il sistema o- 
perativo DOS non accetta, quali ad esempio bar¬ 
re, punto interrogativo, segno di uguale, ecc. 
Se farete questo errore il DOS ve lo segnalerà im¬ 
mediatamente con la scritta ERROR su uno sfon¬ 
do rosso. 

Ad alcuni lettori che ci avevano segnalato di non 
riuscire a trasferire il contenuto del dischetto 
nell’Hard-Disk perchè sul computer appariva subi¬ 
to la scritta error o la mancanza di un file, abbia¬ 
mo consigliato di creare prima una directory con 
il nome ST6, poi di trasferire su questa tutto il con¬ 
tenuto del dischetto e da ultimo di scompattare il 
programma procedendo come segue: 

Quando sul monitor appare il prompt C:\> dovrete 
scrivere: 

C:\>MD ST6 poi premete Enter 

In questo modo riapparirà il prompt C:\> e a que¬ 
sto punto dovrete inserire nel driver il disco che vi 
abbiamo fornito con la sigla DF1170.3 o DF1202.3 
(il contenuto dei due dischetti è identico) e scrive¬ 
re quanto segue: 

C:\>COPY A: *.* C:\ST6 poi premere Enter 

Nota = Rispettate gli spazi: per agevolarvi abbia¬ 
mo colorato in azzurro le scritte che il computer 
farà apparire sul monitor, senza colore quelle che 
dovrete scrivere voi inserendo come spaziatura un 
rettangolo in azzurro. 

Terminato di copiare il contenuto del dischetto 
nell’Hard-disk, apparirà nuovamente la scritta C:\>, 
ma non potrete ancora usare il programma ST6 



Fig.11 Quando trasferite il programma dal 
dischetto nell’Hard-Disk, se volete chiama¬ 
re la directory ST6 in LX1202, quando vi ap¬ 
pare questa riga sostituite C:\ST6 con la 
scritta C:\LX1202 e poi premete Enter. 



Fig.12 Immediatamente tutti i files “com¬ 
pattati” si scompatteranno. Ricordatevi che 
il programma occupa circa 1 MEGA di me¬ 
moria. Non premete nessun tasto durante 
la fase di scompattazione. 



Fig.13 Solo quando sul monitor apparirà la 
scritta BUON DIVERTIMENTO potrete pre¬ 
mere un qualsiasi tasto per uscire. Per ri¬ 
chiamare il programma dovrete scrivere 
C:\>ST6 poi C:\ST6>ST6 ed Enter. 






















































perchè non l’avete ancora scompattato. 

Per farlo dovrete scrivere: 

C:\>CD ST6 poi premete Enter 

Quando vi apparirà C:\ST6>, scrivete: 

C:\ST6>installa poi premete Enter 

Non appena premerete il tasto Enter, sul monitor 
vi apparirà la scritta che questa directory esiste 
già, ma di ciò non preoccupatevi e premete nuo¬ 
vamente Enter e quando vi sarà chiesta la con¬ 
ferma premete per una seconda volta il tasto En¬ 
ter. 

Subito vedrete sul monitor tutti i nomi dei files che, 
abbastanza velocemente, si stanno scompattan¬ 
do (vedi fig.12). 


I PROGRAMMI 

Prima di trasferire tutti i files con l’estensione .A- 
SM nella memoria di un micro ST6, li dovrete as¬ 
semblare per ottenere un file in estensione .HEX 
Eseguita questa operazione, nel computer trove¬ 
rete sempre due identici files, uno ASM ed uno 
HEX. 

Se tenterete di trasferire dall’Hard-disk alla memo¬ 
ria di un micro ST6 un file ASM, il computer se¬ 
gnalerà errore con questa scritta in inglese: 

error can’t open file 

oppure con: 

enter name of source HEX file 

Per sapere se il file richiesto risulta convertito nell’e¬ 
stensione HEX, potrete procedere come segue. 
Quando sul monitor del computer apparirà la fine¬ 
stra dell’Editor (vedi fig.1) premete i tasti ALT F, 
poi F3 e quando sul monitor vi apparirà la fascia 
con la scritta: 

*.ASM 

sostituitela con: 

*.HEX poi premete Enter 

e, in questo modo, vi appariranno tutti i files in 

.HEX. 


I kit che vi serviranno per provare tutte le nostre 

schede sperimentali sono i seguenti: 

LX.1170 = Questo kit, pubblicato nella rivista 
N.172/173, serve per trasferire i programmi che ab¬ 
biamo assemblato e convertito da .ASM in .HEX 
dall’Hard-disk del computer alla memoria di un ST6 
vergine. Questo kit va collegato alla presa uscita 
parallela del computer. 

LX.1202 = Questo kit, pubblicato nella rivista 
N.179, serve per ricevere tutte le schede speri¬ 
mentali che abbiamo già pubblicato e quelle che 
pubblicheremo in seguito. Questa scheda, che non 
va collegata al computer, andrà alimentata con il 
kit LX.1203. 

LX.1203 = Questo kit, pubblicato nella rivista 
N.179, serve per alimentare la scheda LX.1202 e 
tutte le schede sperimentali che inserirete in que¬ 
sta stessa scheda. 

LX.1204 = Questo kit, pubblicato nella rivista 

N.179, provvisto di 4 display a sette segmenti ser¬ 
ve per realizzare dei cronometri-orologi-timer, ecc. 
Questa scheda va inserita nei connettori presenti 
nella scheda LX.1202. 

LX.1205 = Questo kit, pubblicato nella rivista 

N.179, provvisto di 4 relè serve per alimentare lam¬ 

pade-motorini o accendere qualsiasi apparecchia¬ 
tura elettronica. Questa scheda va inserita nei con¬ 
nettori presenti nella scheda LX.1202. 

LX.1206 = Questo kit, pubblicato nella rivista 

N.180, provvisto di 4 Triac serve per alimentare 
delle lampade - motorini o altre apparecchiature e- 
lettroniche che funzionano con tensioni alternate. 
Questa scheda va inserita nei connettori presenti 
nella scheda LX.1202. 


CRONOMET.HEX 

Questo programma è un semplice cronometro, 
quindi per visualizzare i tempi occorre inserire nel 
bus LX.1202 la sola scheda dei display siglata 

LX.1204. 

Se nel bus inserirete le schede dei relè o dei triac, 
non potrete renderle attive perchè nel programma 
non è presente nessuna istruzione per gestirle. 
Una volta caricato su un micro ST6 vergine il pro¬ 
gramma CRONOMET.HEX ed inserito nello zoc¬ 
colo presente sulla scheda bus LX.1202, appena 


alimenterete il circuito sui 4 display apparirà il nu¬ 
mero: 

00:00 

Premendo il pulsante PI il micro comincerà a con¬ 
tare in avanti ad intervalli di tempo di un secondo, 
quindi sui display vedrete apparire i numeri: 

00:01 - 00:02 - 00:03 ecc. 

Sui primi due display di sinistra vedrete i minuti e 
sui display di destra i secondi. 

I due led che separano i display dei minuti e dei 
secondi lampeggeranno con una cadenza di un se¬ 
condo. 

Come noterete, quando si è raggiunto un tempo di 
00:59 secondi, subito dopo si passerà al tempo 
successivo di 01:00, cioè 1 minuto e 00 secondi. 

II massimo numero che potrete visualizzare sarà 
quindi di 99 minuti e 59 secondi, dopodiché ap¬ 
parirà 00:00. 

Se in fase di conteggio premerete PI , il conteggio 
si bloccherà sul tempo raggiunto e premendolo 
nuovamente questo ripartirà dal numero sul quale 
si era fermato. 

Se invece premerete il pulsante P2, il conteggio ri¬ 
partirà da zero, cioè il tempo visualizzato si azze¬ 
rerà. 


DISPLAY.HEX 

Questo programma serve solo per far capire come 
si possa visualizzare il numero desiderato sui 4 
display della scheda siglata LX.1204. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma DISPLAY.HEX ed inserito nello zoccolo 
presente sulla scheda bus LX.1202, non appena 
alimenterete il circuito sui 4 display apparirà il nu¬ 
mero: 

12:34 

e nient’altro. 

Questo programma l’abbiamo composto soltanto 
per farvi capire come si deve scrivere una istru¬ 
zione per gestire in modo seriale l’integrato M.5450. 
Le righe da utilizzare per cambiare questo nume¬ 
ro sono quelle numerate dalla numero 159 alla nu¬ 
mero 162 del listato DISPLAY.ASM: 


Idi 

bcd3,1 

; 159 accende 1 sul display 1 

Idi 

bcd4,2 

; 160 accende 2 sul display 2 

Idi 

bcd1,3 

; 161 accende 3 sul display 3 

Idi 

bcd2,4 

; 162 accende 4 sul display 4 


Quindi basta cambiare il numero dopo la virgola 
in questi registri per modificare il numero visualiz¬ 
zato. 

Poiché questo programma fa molto poco, vi consi¬ 
gliamo di visualizzarlo solo sul monitor e di non me¬ 
morizzarlo su un ST6. 


OROLOGIO.HEX 

Questo programma è un semplice orologio. 

Per poter visualizzare le ore ed i minuti dovrete 
inserire nel bus LX.1202 la sola scheda dei display 
siglata LX.1204. 

Se nel bus inserirete le schede dei relè o dei triac, 
non potrete renderle attive, perchè nel programma 
non è presente nessuna istruzione per gestirle. 
Una volta caricato su un micro ST6 vergine il pro¬ 
gramma OROLOGIO.HEX ed inserito nello zocco¬ 
lo presente nella scheda bus LX.1202, non appe¬ 
na alimenterete il circuito sui 4 display apparirà il 
numero: 

00:00 

I primi due display di sinistra segneranno le ore, 
mentre i due di destra i minuti. 

I due diodi led che separano i due display lam¬ 
peggeranno con una cadenza di 1 secondo. 
Come noterete, raggiunte le ore 23 ed i 59 minu¬ 
ti, dopo 1 minuto si passerà alle 24 ore che ver¬ 
ranno visualizzate con 00:00. 

Per mettere a punto le ore dell’orologio si utiliz¬ 
zerà il pulsante P2 e, per mettere a punto i minu¬ 
ti, il pulsante PI. 

Facciamo presente che potrete solo far avanzare 
i numeri e non indietreggiare. 


RELE.HEX 

Questo programma serve solo per far eccitare dei 
relè o dei triac, quindi nella scheda bus LX.1202 
potrete inserire la sola scheda dei Relè siglata 
LX.1205 o la sola scheda dei Triac siglata 

LX.1206. 

Se inserirete nel bus anche la scheda dei display 
siglata LX.1204 non potrete renderla attiva, perchè 
nel programma non è presente nessuna istruzione 
per gestirla. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma RELE.HEX ed inserito nello zoccolo pre¬ 
sente sulla scheda bus LX.1202, non appena ali- 


meriterete il circuito tutti i relè risulteranno disec¬ 
citati. 

Non appena premerete uno o più dei pulsanti da 
PI a P4 si ecciterà il relè o il triac corrispondente. 
Premendolo una seconda volta, il relè o il triac si 

disecciterà. 


TEMPOR.HEX 

Questo programma è un semplice temporizzato¬ 
re con conteggio all’indietro. 

Nel bus LX.1202 dovrete inserire, oltre alla sche¬ 
da display siglata LX.1204, anche la scheda Relè 
siglata LX.1205, oppure la scheda Triac siglata 
LX.1206. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma TEMPOR.HEX ed inserito nello zoccolo 
presente nella scheda bus LX.1202, non appena 
alimenterete il circuito, tutti i relè o i triac risulte¬ 
ranno diseccitati e sui 4 display vedrete apparire 
il numero: 

03:00 

che indica 03 minuti e 00 secondi. 
Immediatamente, partendo da questo numero, il 
conteggio inizierà a contare all’indietro con una ca¬ 
denza di un secondo, quindi sui display vedrete i 
numeri: 

02:59 - 02:58 - 02:57 ecc. 

Quando apparirà il numero 00:00, si ecciterà il so¬ 
lo relè 1 presente nella scheda LX.1205 oppure il 
solo triac 1 presente nella scheda LX.1206. 

Per ricominciare il ciclo basterà premere il pulsan¬ 
te PI presente sulla scheda bus LX.1202. 

Tutti i pulsanti presenti sulla scheda del relè o del 
triac non risultano attivati. 


PER cambiare i TEMPI 

Per cambiare il tempo da noi prefissato 03:00 ba¬ 
sterà modificare i valori impostati sulle righe 239 e 
240 nel listato del programma TEMPOR.ASM. 
Come tempo massimo potrete partire da 99 mi¬ 
nuti e 59 secondi. 

Attualmente sulla riga 240 che è la riga dei minu¬ 
ti troverete riportato il numero 3: 

Idi minuti,3 ;240 carica 3 minuti 

quindi se volete partire da 12 minuti basterà sem¬ 


plicemente scrivere 12 al posto di 3 come qui sot¬ 
to riportato: 

Idi minuti,12 ;240 carica 12 minuti 

Se volete cambiare anche i secondi dovrete mo¬ 
dificare il numero sulla riga 239 che attualmente è 

0 : 

Idi secondi,0 ;239 carica 0 secondi 

Ammesso che ai 12 minuti già presenti vogliate 
sommare 28 secondi, dovrete scrivere nella riga 
239 il numero 28 come qui sotto riportato: 

Idi secondi,28 ;239 carica 28 secondi 

Così facendo il conteggio partirà da 12:28 e quando 
raggiungerà lo 00:00 si ecciterà il relè 1 o il triac 1 . 

Nota = Anche se nella riga 241 troverete: 

Idi ore,0 ;241 carica 0 ore 

questo parametro ore non viene utilizzato, pertan¬ 
to questa istruzione non dovrete mai modificarla. 

Se in sostituzione del relè 1 volete eccitare un al¬ 
tro relè ad esempio il relè 2, o un corrispondente 
triac, dovrete modificare la riga 262: 

loop3 set 4,port_b ; 262 accende RL1 

sostituendo dopo il set il numero 4 con il numero 
5 come qui sotto riportato: 

loop3 set 5,port_b ;262 eccita RL2 

Se volete eccitare il relè RL3, dovrete sostituire il 
numero 4 con il numero 6: 

loop3 set 6,port_b ; 262 eccita RL3 

Se volete eccitare il relè RL4 dovete sostituire il nu¬ 
mero 4 con il numero 7: 

loop3 set 7,port_b ;262 eccita RL4 

Se volete eccitare contemporaneamente tutti e 4 i 
relè, dovrete aggiungere tutte queste righe: 


loop3 set 

4,port_b 

; 262 eccita RL1 

set 

5,port_b 

; 262.1 eccita RL2 

set 

6,port_b 

; 262.2 eccita RL3 

set 

7,port_b 

;262.3 eccita RL4 



In pratica, se vi interessa eccitare i soli relè RL1, 
RL3 ed RL4 dovrete scrivere queste tre righe: 


loop3 set 

4, port_b 

; 262 eccita RL1 

set 

6, port_b 

; 262.1 eccita RL3 

set 

7, port_b 

;262.2 eccita RL4 


Vi ricordiamo che tutte le volte che modificherete 
un programma, lo dovrete salvare digitando il ta¬ 
sto F2, poi lo dovrete riassemblare premendo i ta¬ 
sti ALT T, poi il tasto A, dopodiché lo potrete tra¬ 
sferire nella memoria di un ST6. 


TIMER.HEX 

Questo programma è un semplice temporizzato¬ 
re con conteggio in avanti. 

Nel bus LX.1202 dovrete inserire oltre alla scheda 
display siglata LX.1204, anche la scheda relè si¬ 
glata LX.1205, oppure la scheda triac siglata 
LX.1206. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma TIMER.HEX ed inserito nello zoccolo pre¬ 
sente sulla scheda bus LX.1202, non appena ali¬ 
menterete il circuito, tutti i relè o i triac risulteran¬ 
no diseccitati e sui 4 display vedrete apparire il 
numero: 

00:00 

Immediatamente, partendo da questo numero, il 
conteggio inizierà a contare in avanti con una ca¬ 
denza di un secondo, quindi sui display vedrete i 
numeri salire: 

00:01 - 00:02 - 00:03 ecc. 

e quando raggiungerete il numero 03:00, corri¬ 
spondente a 3 minuti e 00 secondi, subito si ec¬ 
citerà il relè 1 presente nella scheda LX.1205 op¬ 
pure il solo triac 1 presente nella scheda LX.1206. 
Per ricominciare il ciclo basterà premere il pulsan¬ 
te PI presente sulla scheda bus LX.1202. 

Tutti i pulsanti presenti sulla scheda dei relè o dei 
triac non risultano attivati. 


PER cambiare i TEMPI 

Per cambiare il tempo da noi prefissato 03:00 ba¬ 
sterà modificare i valori impostati sulle righe 248 e 
252 nel listato del programma TEMPOR.ASM. 
Come tempo massimo potrete raggiungere i 99 mi¬ 
nuti e 59 secondi. 


Attualmente sulla riga 248, che è la riga dei se¬ 
condi, troverete riportato il numero 0: 

cpi a,0 ; 248 compara con zero 

e nella riga 252, che è quella dei minuti, trovere¬ 
te riportato: 

cpi a,3 ; 252 compara con 3 

Se volete ad esempio eccitare il relè RL1 dopo 15 
secondi dall’accensione, basterà inserire nella ri¬ 
ga 248: 

cpi a,15 ; 248 compara con 15 secondi 

ed inserire il numero 0 nella riga 252 dei minuti: 
cpi a,0 ;252 compara con 0 minuti 

Con queste modifiche, quando sul display apparirà 
il numero 00:15 il relè RL1 si ecciterà. 

Se volete far eccitare il relè dopo 30 minuti e 
5 secondi basterà inserire il numero 5 nella ri¬ 
ga 248: 

cpi a,5 ; 248 compara con 5 secondi 

ed inserire il numero 30 nella riga 252 dei minuti: 
cpi a,30 ;252 compara con 30 minuti 

Con queste modifiche, quando sul display apparirà 
il numero 30:05 il relè RL1 si ecciterà. 

Nota = Anche se nella riga 256 troverete riportato: 

Idi ore,0 ; 256 carica 0 ore 

questo parametro ore non viene utilizzato, per¬ 
tanto non dovrete mai modificare questa istru¬ 
zione. 

Se in sostituzione del relè 1 volete eccitare un al¬ 
tro relè, ad esempio il relè 2, o un corrispondente 
triac, dovrete modificare la riga 259: 

loop3 set 4,port_b ; 259 eccita RL1 

sostituendo dopo il set il numero 4 con il numero 
5 come qui sotto riportato: 

loop3 set 5,port_b ;259 eccita RL2 


Se volete eccitare il relè RL3 dovrete sostituire il 
numero 4 con il numero 6: 

loop3 set 6,port_b ; 259 eccita RL3 

Per eccitare il relè RL4 dovrete sostituire il nume¬ 
ro 4 con il numero 7: 

loop3 set 7,port_b ;259 eccita RL4 


Per eccitare contemporaneamente tutti e 4 i relè 
dovrete aggiungere le seguenti righe: 


loop3 set 

4,port_b 

;259 eccita RL1 

set 

5,port_b 

;259.1 eccita RL2 

set 

6,port_b 

;259.2 eccita RL3 

set 

7,port_b 

;259.3 eccita RL4 


Se vi interessa eccitare i soli relè RL1, RL3 ed RL4, 
dovrete scrivere queste tre righe: 


loop3 set 

4,port_b 

; 259 eccita RL1 

set 

6,port_b 

;259.1 eccita RL3 

set 

7,port_b 

;259.2 eccita RL4 


Vi ricordiamo che tutte le volte che modificherete 
un programma, lo dovrete salvare premendo il ta¬ 
sto F2, poi lo dovrete riassemblare premendo i ta¬ 
sti ALT T, poi il tasto A, dopodiché lo potrete tra¬ 
sferire nella memoria di un ST6. 


TRIAC.HEX 

Questo programma è una dimostrazione di come 
si possano eccitare in sequenza dei Triac o dei 
Relè. 

Nel bus LX.1202 dovrete inserire la sola scheda 
siglata LX.1206 o, in sua sostituzione, quella dei 
relè siglata LX.1205. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma TRIAC.HEX ed inserito nello zoccolo pre¬ 
sente sulla scheda bus LX.1202, non appena ali¬ 
menterete il circuito vedrete eccitarsi in sequen¬ 
za, con un intervallo di 1 secondo, i quattro triac 
o i quattro relè se avrete inserito la scheda 
LX.1205. 

Nota = In questo programma i pulsanti P1-P2-P3- 
P4 presenti nella scheda dei triac o dei relè non ri¬ 
sultano attivati, quindi anche se li premerete non 
accadrà nulla. 

Questo programma può essere modificato per ec¬ 
citare i triac in senso inverso a quello indicato, mo¬ 
dificando anche i tempi oppure facendo accende¬ 


re delle coppie di triac, ecc., modificando sempli¬ 
cemente il numero binario riportato nelle righe 74- 

76-78-80-82-84-86-88 . 


Idi 

Idi 

Idi 

Idi 

Idi 

Idi 

Idi 

Idi 


port_b,10000000b 

;74 eccita il triac TRC4 

port_b,01000000b 

;76 eccita il triac TRC3 

port_b,00100000b 

;78 eccita il triac TRC2 

port_b,00010000b 

;80 eccita il triac TRC1 

port_b,00100000b 

;82 eccita il triac TRC2 

port_b,01000000b 

;84 eccita il triac TRC3 

port_b,10000000b 

;86 eccita il triac TRC4 

port_b,00000000b 

;88 diseccita tutti i triac 


Come noterete, dopo la dicitura port_b ci sono ot¬ 
to numeri, ma quelli che dovrete modificare sono 
solo i primi quattro, cioè 1000 - 0100 - 0010 - 0001. 
Se nella riga 88 sostituirete i quattro 0000 con 1111, 
tutti i quattro triac si ecciteranno anziché disecci¬ 
tarsi. 

Per far lampeggiare per una infinità di volte il so¬ 
lo TRC4, dovrete scrivere in tutte le righe 74-76- 
78-80-82-84-86 solo 1000. 

Per accendere contemporaneamente TRC4-TRC3 
dovrete scrivere nelle righe 74-76 il numero 1100. 


PER cambiare i TEMPI 

Per modificare i tempi di intervallo tra l’accensio¬ 
ne di un triac e quella del successivo, occorre mo¬ 
dificare la subroutine chiamata delay. 

Anche se prima non le abbiamo riportate, tra una 
riga e l’altra delle 74-76-78-80-82-84-86-88 trove¬ 
rete una istruzione cali delay che chiama una su¬ 
broutine: 


Idi 

port_b,10000000b 

;74 eccita il triac TRC4 

cali 

delay 

;75 esegue ritardo 

Idi 

port_b,01000000b 

;76 eccita il triac TRC4 

questa subroutine la troverete nelle righe 59 - 60. 

Idi 

x,255 

;59 carica in x 255 

dell Idi 

V,255 

;60 carica in y 255 


Il massimo ritardo che potete ottenere è di circa 1 
secondo, perchè disponendo di registri X-Y ad 8 
bit non potrete mettere un numero maggiore di 
255. 

Volendo ridurre il ritardo, dovrete inserire dei nu¬ 
meri minori, ad esempio per ottenere all’incirca 1/2 
secondo dovrete caricare nella riga 59 il numero 
127 come qui sotto riportato: 


x,127 

;59 carica in x 127 

y,255 

;60 carica in y 255 



Se volete ottenere 1/4 di secondo dovrete cam¬ 
biare le due righe come segue: 


x,127 

;59 carica in x 127 

y,127 

;60 carica in y 127 


Se anziché ridurli li voleste aumentare, potrete 
farlo utilizzando questo “trucchetto”. 

Tutte le istruzioni che trovate inserite tra le righe 
delle istruzioni dal numero 74 alla 88 con la paro¬ 
la cali delay, le dovrete scrivere due-tre-quattro 
o più volte, ad esempio: 


Idi 

port_b,10000000b 

; 74 eccita TRC4 

cali 

delay 

;75 esegue ritardo 

cali 

delay 

raddoppia tempo 

cali 

delay 

; triplica tempo 

Idi 

port_b,01000000b 

; 76 eccita TRC3 


Quindi inserendo più o meno righe di cali delay tra 
una riga e l’altra potrete variare i tempi di eccita¬ 
zione tra un triac e l’altro. 


CLOCK.HEX 

Questo programma CLOCK anche se funziona co¬ 
me orologio è totalmente diverso dal precedente 
programma OROLOGIO, perchè oltre a visualiz¬ 
zare le ore e i minuti permette di eccitare un relè 
o un triac ad un’ora prestabilita e di diseccitarlo 
dopo un tempo che voi stessi potrete prefissare mo¬ 
dificando alcune righe del programma. 

Per farlo funzionare occorre inserire nel bus 
LX.1202 la scheda dei display siglata LX.1204 e 
quella dei relè siglata LX.1205, oppure quella dei 
triac siglata LX.1206. 

Prima di spiegarvi quali righe dovrete modificare, 
consigliamo ai meno esperti di leggere attenta¬ 
mente tutto l’articolo, dopodiché potranno modifi¬ 
care i parametri nelle sole righe che noi indiche¬ 
remo. 

Come abbiamo accennato, il programma 
CLOCK.HEX ci dà la possibilità di eccitare o di¬ 
seccitare uno o più relè anche contemporanea¬ 
mente, su orari che noi stessi potremo stabilire, pur¬ 
ché non si superino più di 8 cicli o periodi nell’ar¬ 
co delle 24 ore. 

Questo programma potrà servire per accendere o 
spegnere una o più caldaie, delle insegne lumino¬ 
se ad orari prestabiliti, ecc. 

Per mettere a punto le ore dell’orologio si utiliz¬ 
zerà il pulsante P2 e per mettere a punto i minuti 
il pulsante PI. 


Facciamo presente che è possibile soltanto far a- 
vanzare i numeri e non indietreggiare. 

Appena accenderete l’orologio tutti i 4 relè o triac 
partiranno eccitati. 

Se volete che all’accensione dell’orologio tutti i relè 
risultino diseccitati, dovrete andare alla riga N.59 
dove troverete questa istruzione: 

Idi port_b,11110011b 

e modificarla inserendo in sostituzione degli 1 de¬ 
gli 0 come qui sotto riportato: 

Idi port_b,00000011 b 

Nota = Anche se questa riga è composta da 8 nu¬ 
meri, dovrete modificare solo i primi 4 di sinistra. 

Se volete far eccitare all’accensione il solo relè 
RL4, dovrete mettere un 1 in corrispondenza del¬ 
la prima cifra di sinistra come qui sotto riportato: 

Idi port_b,10000011 

A questo punto vi spieghiamo che cosa s’intende 
per 8 cicli o periodi da utilizzare nell’arco delle 24 
ore che troverete riportati in queste righe: 

1 ° periodo = righe 309 - 310 - 311 
2° periodo = righe 316 - 317 - 318 
3° periodo = righe 323 - 324 - 325 
4° periodo = righe 330 - 331 - 332 
5° periodo = righe 337 - 338 - 339 
6° periodo = righe 344 - 345 - 346 
7° periodo = righe 351 - 352 - 353 
8° periodo = righe 358 - 359 - 360 

Ogni ciclo è composto da 3 righe d’istruzioni, quin¬ 
di nel 1 ° ciclo o periodo del nostro programma tro¬ 
verete: 


.byte 

02 

;309 riga delle ore 

.byte 

30 

;310 riga dei minuti 

.byte 

lllOOOOOb 

;311 riga per comando relè 


Attualmente il 1 ° ciclo inizia alle ore 2,30 di not¬ 
te. 

Per modificare l’orario basterà mettere nella prima 
riga l’ora che vi interessa, ad esempio 05-06-10, e 
nella seconda riga i relativi minuti, ad esempio 00 

-10 - 30 - 50. 

Nella terza riga sono riportati i relè che desiderate 
eccitare e quelli che non desiderate eccitare all’o¬ 
rario da noi prestabilito. 

Mettendo un 1 il relè si ecciterà, mettendo uno 0 

si disecciterà. 

Ciò che dovrete modificare in questa terza riga so- 



no solo i primi quattro numeri di sinistra posti do¬ 
po la parola byte. 

Tenete presente che il primo numero di sinistra pi¬ 
loterà il relè RL4 e l’ultimo numero di destra il relè 
RL1, quindi avrete in ordine: 

RL4-RL3-RL2-RL1 

Per farvi capire come modificare tutti questi nume¬ 
ri vi faremo un semplice esempio. 

Ammesso che alle 06,10 desideriate eccitare i relè 
RL2-RL1, scriverete nelle righe 309 - 310 - 311 (1 ° 
ciclo) questi numeri: 


byte 06 

;309 riga delle ore 

byte 10 

;310 riga dei minuti 


.byte OOllOOOOb ; 311 riga per comando relè 


Se alle 09,30 vorrete diseccitare ed eccitare il so¬ 
lo relè RL4, dovrete scrivere nelle righe 316 - 317 
- 318 (2° ciclo) questi numeri: 

.byte 09 

;316 riga delle ore 

.byte 30 

;317 riga dei minuti 

.byte lOOOOOOOb 

;318 riga per comando relè 

Se alle 12,00 vorrete diseccitare anche il relè RL4, 

dovrete scrivere nelle 
ciò) questi numeri: 

righe 323 -324 -325 (3° ci- 

.byte 12 

;323 riga delle ore 

.byte 00 

;324 riga dei minuti 

.byte OOOOOOOOb 

;325 riga per comando relè 

Se alle 18,45 vorrete eccitare tutti i relè, dovrete 
scrivere nelle righe 330 - 331 - 332 (4° ciclo) que- 

sti numeri: 


.byte 18 

;330 riga delle ore 

.byte 45 

;331 riga dei minuti 

.byte llllOOOOb 

;332 riga per comando relè 

Se alle 22,30 vorrete 

diseccitare i relè RL4-RL3, 

dovrete scrivere nelle 
ciò) questi numeri: 

righe 337 - 338- 339 (5° ci- 

.byte 22 

;337 riga delle ore 

.byte 30 

;338 riga dei minuti 

.byte OOllOOOOb 

;339 riga per comando relè 

Se alle 23,40 vorrete 

lasciare eccitato il solo relè 

RL1 , dovrete scrivere nelle righe 344 - 345 - 346 
(6° ciclo) questi numeri: 

.byte 23 

;344 riga delle ore 

.byte 40 

;345 riga dei minuti 

.byte OOOIOOOOb 

;346 riga per comando relè 


Se alle 24,00 vorrete diseccitare anche questo 
relè, dovrete scrivere nelle righe 351 - 352 - 353 
(7° ciclo) questi numeri: 


.byte 

00 

;351 riga delle ore 

.byte 

00 

;352 riga dei minuti 

.byte 

OOOOOOOOb 

; 353 riga per comando relè 


Avendo utilizzato solo 7 cicli degli 8 disponibili, se 
l’ultimo non vi interessa lo potrete cancellare op¬ 
pure inibire, mettendo davanti alle righe 358 - 359 
- 360 un punto e virgola o mettendo sulla terza ri¬ 
ga OOOOOOb. 

Potrete aggiungere altri cicli se 8 risultassero in¬ 
sufficienti. 

Facciamo presente che questi cicli si ripeteranno 
automaticamente all’Infinito agli stessi orari tutti i 
giorni. 


TIME90.HEX 

Questo programma è un timer che, contando in a- 
vanti, ecciterà un relè o un triac quando raggiun¬ 
gerà i minuti e i secondi da noi prefissati. 

Per farlo funzionare occorre inserire nel bus 
LX.1202 la scheda dei display siglata LX.1204 e 
quella dei relè siglata LX.1205, oppure quella dei 
triac siglata LX.1206. 

Non appena alimenterete il circuito, il conteggio 
partirà da 00:00 e inizierà a contare in avanti; a 
questo punto potrete utilizzare i pulsanti PI e P2 
presenti sulla scheda display LX.1204. 

Premendo PI il conteggio si ferma. 

Premendo nuovamente PI il conteggio riparte dal 
numero sul quale si era fermato. 

Premendo P2 il contatore si resetta. 

Premendo PI il contatore riparte da 00:00. 

Nota = Il pulsante P2 di reset sarà attivo solamente 
se avrete fermato il conteggio con PI. Se preme¬ 
rete P2 mentre è attivo il conteggio, questo non si 
azzererà. 

I pulsanti presenti sulle schede Triac e Relè non ri¬ 
sultano attivati. 

II conteggio del display arriva ad un massimo di 89 

minuti e 59 secondi. 

Il programma TIME90.ASM, come potrete notare, 
dispone di 4 cicli perchè quattro sono i relè e i 
triac presenti sulle schede sperimentali. 

1 “ciclo = Dopo 20 secondi dall’accensione si ec¬ 
citerà il solo relè RL1. 



Ovviamente sui display vedrete apparire 19 e, 
quando questo numero raggiungerà 00:00, il relè 
si ecciterà. 

2“ciclo = Passando al secondo ciclo, questo relè 
rimarrà eccitato per un tempo da noi prefissato in 

I minuto e 30 secondi e raggiunto questo tempo 
il relè RL1 si disecciterà e automaticamente si ec¬ 
citerà il relè RL2. 

II relè RL2 si ecciterà un secondo dopo che sui di¬ 
splay sarà apparso il numero 01:29 che cambierà 

in 00:00. 

3° ciclo = Dopo 47 secondi, cioè quando sul di¬ 
splay il numero 46 passerà sullo 00, il relè RL2 si 

disecciterà e si ecciterà il terzo relè RL3. 

4° ciclo = Il conteggio continuerà ed allo scoccare 
dei 3 minuti e 00 secondi (tempo da noi prefis¬ 
sato) si disecciterà il relè RL3 e si ecciterà il relè 
RL4, cioè si ritornerà al 1 “ciclo per ripetere all’in¬ 
finito i quattro cicli. 

Per variare i tempi che noi abbiamo prefissato do¬ 
vrete variare queste righe: 

1 ° ciclo = righe 289 - 290 
2° ciclo = righe 295 - 296 
3“ ciclo = righe 301 - 302 
4° ciclo = righe 307 - 308 

Se volete che il 1 “ ciclo abbia una durata di 1 mi¬ 
nuto e 30 secondi, dovrete inserire nelle sue ri¬ 
ghe questi numeri: 

Idi stsex,30 ;289 secondi per RL1 

Idi stmix,1 ;290 minuti per RL1 

Se volete che il 2° ciclo abbia una durata di 50 se¬ 
condi, dovrete inserire nelle sue righe questi numeri: 

Idi stsex,50 ; 295 secondi per RL1 

Idi stmix,00 ;296 minuti per RL1 


Se volete che il 3°ciclo abbia una durata di 15 mi¬ 
nuti e 20 secondi, dovrete inserire nelle sue righe 
questi numeri: 


Idi 

stsex,20 

;301 secondi per RL1 

Idi 

stmix,15 

;302 minuti per RL1 

Se volete che il 4° 

ciclo abbia una durata di 2 mi- 

nuti e 10 secondi, dovrete inserire nelle sue righe 

questi numeri: 


Idi 

stsex,10 

;307 secondi per RL1 

Idi 

stmix,2 

;308 minuti per RL1 


Nelle righe 292/293 - 298/299 - 304/305 - 310/311 

sono riportate le sigle dei relè che volete eccitare 
e di quelli che volete rimangano diseccitati. 
Guardando l’esempio riportato nel programma 
CLOCK.ASM saprete già che scrivendo questa i- 
struzione: 

Idi port_b,11110011b 

potrete eccitare ad ogni ciclo anche più relè a vo¬ 
stra scelta. 

Nei primi quattro numeri di sinistra (vedi 1111) do¬ 
vrete mettere un 1 sul relè che volete far eccitare 
ed uno 0 se non lo volete eccitare. 


TEMP90.HEX 

Questo programma è un timer che fa esattamen¬ 
te l’inverso del programma TIME90, cioè conta 
all’indietro e quando raggiunge lo 00:00 eccita i 
relè. 

I relè, come per il programma precedente, li ecci¬ 
terete in 4 cicli e come tempo massimo di par¬ 
tenza potrete impostare 90 minuti e 00 secondi. 
Non appena alimenterete il circuito, il conteggio 
partirà da 00:20 (questo tempo lo abbiamo pre¬ 
scelto noi, ma poi vi spiegheremo come modificar¬ 
lo) e procederà all’indietro. 

Dopo che avrà avuto inizio il conteggio, potrete u- 
tilizzare i pulsanti PI e P2 presenti sulla scheda di¬ 
splay LX.1204. 

Premendo PI il conteggio si ferma. 

Premendo nuovamente PI il conteggio riparte dal 
numero sul quale si era fermato. 

Premendo P2 il contatore si resetta. 

Premendo PI il contatore riparte dal tempo che a- 
vete impostato come partenza per il conteggio 
all’indietro. 

Nota = Il pulsante P2 di reset sarà attivo solamente 
se avrete fermato il conteggio con PI . Se preme¬ 
rete P2 mentre è attivo il conteggio, questo non si 
azzererà. Premendo P2 per resettarlo, è intuitivo 
che contando all’indietro sul display ritorni il tem¬ 
po di partenza, cioè 00:20. 

Nei 4 cicli impostati otterrete queste condizioni: 

1 “ciclo = All’accensione si ecciterà il solo relè RL1 
e sui display apparirà 00:20 e a questo punto avrà 
inizio il conteggio alla rovescia che si fermerà sul¬ 
lo 00:00. 


2° ciclo = Dopo un secondo si ecciterà il relè RL2 
e a questo punto inizierà il secondo ciclo, che farà 
apparire sui display 01:30 (tempo 1 minuto e 30 
secondi) che, secondo per secondo, decremen- 
terà fino ad arrivare a 00 : 00 . 

3° ciclo = A questo punto si ecciterà il relè RL3 e 
sui display apparirà 00:47 che decrementerà fino 
ad arrivare allo 00 : 00 . 


4° ciclo = L’ultimo ciclo farà eccitare il relè RL4 e 
farà apparire sui display il numero 03:00 (3 minu¬ 
ti). Quando con il conteggio alla rovescia si arri¬ 
verà al numero 00:00, questo relè si disecciterà e 
contemporaneamente si disecciterà il relè RL1, 
cioè si ritornerà al 1 ° ciclo per ripetere all’infinito i 
quattro cicli. 

Per variare i tempi prefissati dovrete variare que¬ 
ste righe: 

1 ° ciclo = righe 290 - 291 
2° ciclo = righe 296 - 297 
3° ciclo = righe 302 - 303 
4° ciclo = righe 308 - 309 

Se volete che il 1 0 ciclo abbia una durata di 1 mi¬ 
nuto e 30 secondi, dovrete inserire nelle sue ri¬ 
ghe questi numeri: 


Idi 

stsex,30 

;290 secondi per RL1 

Idi 

stmix,1 

;291 minuti per RL1 


Se volete che il 2° ciclo abbia una durata di 50 se¬ 
condi, dovrete inserire nelle sue righe questi nu¬ 
meri: 

Idi stsex,50 ;296 secondi per RL1 

Idi stmix,00 ; 297 minuti per RL1 


Se volete che il 3° ciclo abbia una durata di 15 mi¬ 
nuti e 20 secondi, dovrete inserire nelle sue righe 
questi numeri: 


Idi 

stsex,20 

;302 secondi per RL1 

Idi 

stmix,15 

;303 minuti per RL1 


Se volete che il 4° ciclo abbia una durata di 2 mi¬ 
nuti e 10 secondi, dovrete inserire nelle sue righe 
questi numeri: 

Idi stsex,10 ; 308 secondi per RL1 

Idi stmix,2 ; 309 minuti per RL1 

Nelle righe 292/293 - 298/299 - 304/305 - 310/311 


sono riportate le sigle dei relè che si ecciteranno 
e di quelli che si disecciteranno. 

Anche in questo programma possiamo sostituire le 
righe sopra menzionate con questa sola riga d’i¬ 
struzione: 

Idi port_b!l1110011b 

Nei primi quattro numeri di sinistra (vedi 1111) do¬ 
ve metterete 1 il relè si ecciterà, dove metterete 0 

si disecciterà. 


NOTA 

I programmi che vi abbiamo fornito e che in segui¬ 
to vi forniremo sono a sfondo didattico e servono 
per far capire ai principianti come si debba scrive¬ 
re un’istruzione per ottenere una specifica funzio¬ 
ne e per questo abbiamo aggiunto, di fianco ad o- 
gni riga di programma, un commento. 

Blocchi di un programma si possono prelevare e 
trasferire su un altro programma, cosa che potrete 
fare quando avrete già acquisito una certa espe¬ 
rienza. 


COSTO DI REALIZZAZIONE 

Tutti i componenti necessari per la realizzazione di 
questa scheda, compresi circuito stampato, con¬ 
nettore, triac da 500 Volt 5 Amper, fotoaccopiato- 
ri, zoccoli, pulsanti, morsettiere, condensatori e re¬ 


sistenze (vedi fig.8).€ 18,60 

Il solo circuito stampato LX.1206 .€ 4,91 


Nota = Nel kit non è incluso il dischetto dei pro¬ 
grammi DF1202.3 perchè già fornito agli acquiren¬ 
ti del kit LX.1202. 

A chi non avesse acquistato questo kit e volesse il 
solo dischetto dei programmi, possiamo inviarlo a 
€ 6,20 più le spese postali. 

Ai prezzi riportati, già comprensivi di IVA, andranno 
aggiunte le sole spese di spedizione a domicilio. 




Chissà quanti di voi essendo in possesso di un di¬ 
splay LCD avranno tentato di far apparire un nu¬ 
mero senza riuscirci, pur avendolo alimentato cor¬ 
rettamente, collegato i vari segmenti e controllato 
più volte il montaggio per verificare di non aver 
commesso involontariamente qualche errore. 

Il motivo per il quale non siete riusciti ad accen¬ 
derlo ve lo spiegheremo in questo articolo, quindi 
ammesso che non vi interessi sapere come si pro¬ 
grammi un microprocessore ST6 per pilotare un di¬ 
splay LCD, vi consigliamo ugualmente di leggerlo. 


GESTIRE un DISPLAY a 7 SEGMENTI 

Se volessimo pilotare 4 display a 7 segmenti con 
un integrato driver, questo dovrebbe avere come 


- il piedino 23 dell’Enable lo dovremo collegare a 

massa. 

- il piedino 22 del Data serve per ricevere i dati se¬ 
riali necessari per far accendere i vari segmenti. 

- il piedino 21 del Clock serve per ricevere un tre¬ 
no di onde quadre per sincronizzare i segnali. 

I due piedini supplementari d’uscita corrispondenti 
ai bit 33-34 potrebbero risultare utili per far lam¬ 
peggiare ad una cadenza di 1 secondo due diodi 
led interposti tra i due numeri delle ore e dei mi¬ 
nuti, se realizzeremo un orologio. 

I piedini d’uscita di questo integrato, come visibi¬ 
le in fig.1, vengono indicati BIT1 - BIT2 - BIT3, 
ecc. 

Quando tutti i segmenti dei display sono spenti, 
nel piedino del clock entrerà un treno di onde qua¬ 
dre e nel piedino data il solo impulso di Start (bit 


SCHEDA con DISPLAY 


Dopo avervi presentato una scheda per eccitare dei relè, una per pilo¬ 
tare dei triac e una terza per pilotare dei normali display a 7 segmenti, 
oggi vogliamo proporvi una scheda per display numerici LCD dopodi¬ 
ché passeremo ai display alfanumerici. 


minimo 32 piedini d’uscita, infatti oltre ai 7 seg¬ 
menti presenti su ogni display per un totale di 4 x 
7 = 28 terminali, essendo presente su ognuno di 
questi il punto decimale, dovremo aggiungere al¬ 
tri 4 terminali e, in tal modo, otterremo un totale di 
32 piedini. 

Come già saprete, per accendere uno o più seg¬ 
menti basterà alimentarli con una tensione che po¬ 
tremo prelevare da una normale pila. 

Per pilotare 4 display esistono degli integrati prov¬ 
visti di 34 piedini d’uscita necessari per accende¬ 
re tutti i vari segmenti. 

Per l’ingresso troviamo invece solo 3 piedini per¬ 
chè questi lavorano in modo seriale. 

Questi 3 piedini d’ingresso sono chiamati: 

Enable 

Data 

Clock 

Nell’integrato driver tipo M.5450 in grado di pilo¬ 
tare 4 display a 7 segmenti: 


0) e due impulsi, uno di Load (bit 35) ed uno di Re¬ 
set (bit 36)(vedi fig.2). 

A questo punto potremo assegnare ciascuno di 
questi 34 bit ad un singolo segmento presente in 
ogni display come visibile in fig.2 e come riportato 
nella Tabella N.1). 

Se in questi 4 display volessimo accendere il nu¬ 
mero 1 0 3 2 tramite il programma software, do¬ 
vremmo portare a livello logico 1 tutti i bit corri¬ 
spondenti ai segmenti che desideriamo accendere. 

Sul display N.1, dovendo accendere i segmenti B- 
C, dovremo portare a livello logico 1 i bit 2-3. 
Sul display N.2, dovendo accendere i segmenti A- 

B-C-D-E-F, dovremo portare a livello logico 1 i bit 
9-10-11-12-13-14. 

Sul display N.3, dovendo accendere i segmenti A- 
B-C-D-G, dovremo portare a livello logico 1 i bit 
17-18-19-20-23. 

Sul display N.4, dovendo accendere i segmenti A- 
B-G-E-D, dovremo portare a livello logico 1 i bit 
25-26-31-29-28 (vedi fig.3). 
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Per accendere un numero su un normale di¬ 
splay a 7 segmenti è sufficiente portare a “li¬ 
vello logico 1” i bit che pilotano i segmenti in¬ 
teressati (vedi figg.2-3). 
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Come avrete intuito, basta portare a livello logico 
1 uno di questi 34 bit per far apparire un numero 
oppure anche una lettera, ad esempio una L, una 
C o una H. 

Tramite software, il display 1 potremo farlo diven¬ 
tare il 4° oppure il 3° in modo da adattarlo al dise¬ 
gno del circuito stampato. 

Un altro particolare molto importante da sottoli¬ 
neare è quello di non confondere il livello logico 
del bit con il livello logico che in pratica ci ritrovere¬ 
mo sul piedino d’uscita dell’integrato che, come 
potrete constatare, risulta invertito, quindi portan¬ 
do ad esempio i bit 25-26 a livello logico 1 , sui cor¬ 
rispondenti piedini 33-32 dell’integrato M.5450 (ve¬ 
di Tabella N.1) ci ritroveremo un livello logico 0. 
Quindi se qualcuno andasse a controllare con un 
tester la tensione presente sui piedini d’uscita che 
accendono un segmento, troverebbe 0 volt e non 
una tensione positiva. 


GESTIRE un DISPLAY LCD 

Come già spiegato, se volessimo pilotare un di¬ 
splay a led con 4 cifre con un integrato driver, 
questo dovrebbe avere 34 piedini d’uscita. 

Per quanto riguarda i display LCD dobbiamo far 
presente che il punto decimale che dovrebbe ri¬ 
sultare presente sul 4° display spesso viene so¬ 
stituito da due punti posti tra le prime due e le ul¬ 
time due cifre. 


Questi due punti vengono spesso utilizzati negli o- 
rologi per dividere le ore dai minuti. 

A differenza del drive M.5450, utilizzato per pilo¬ 
tare i display a 7 segmenti, che dispone di tre in¬ 
gressi chiamati Enable-Data-Clock, il drive 
M.8438/AB6, utilizzato per i display LCD, dispone 
di tre ingressi chiamati: 

Strobe 

Data 

Clock 

- Il piedino 2 dello Strobe si porta a livello logico 
1 ogni volta che deve inviare al display il treno dei 

dati. 

- Il piedino 34 del Data serve per ricevere i dati se¬ 
riali necessari per far accendere i vari segmenti. 

- Il piedino 40 del Clock invia un treno di onde qua¬ 
dre per sincronizzare i segnali (vedi fig.5). 

Come potrete notare, il drive per un display LCD 
ha l’ingresso Strobe che mancava nel drive per di¬ 
splay a 7 segmenti a led ed ha in più un piedino 
chiamato Back/Plane (piedino 30) che viene uti¬ 
lizzato per alimentare il display con un’onda qua¬ 
dra di circa 80 Hertz. 

Quindi i quattro display LCD non vengono alimen¬ 
tati da una tensione continua, ma da una tensio¬ 
ne che cambia in continuità il suo livello logico da 
1 a 0 e questo, come vedremo, è indispensabile 
per poter accendere i vari segmenti. 
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BIT 18 = B1 
BIT 19 = CI 
BIT 20 = DI 
BIT 21 = E1 
BIT 22 = FI 
BIT 23 = Gl 
BIT 24 = DPI 
BIT 25 = A2 
BIT 26 = B2 
BIT 27 = C2 
BIT 28 = D2 
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BIT 32 = DP2 
BIT 33 = DL1 
BIT 34 = DL2 
ENABLE 
DATA 
CLOCK 


Fig.1 Per pilotare 4 display a 7 segmenti occorre un integrato drive tipo M.5450 o altri equiva¬ 
lenti. Dei tre piedini d’ingresso, quello indicato Enable viene collegato a massa, e quelli indica¬ 
ti Data e Clock vengono utilizzati per ricevere i dati seriali e i segnali di sincronismo. 
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Fig.2 Poiché per ogni display sono necessari 8 bit (uno serve per il punto decimale - ve¬ 
di Tabella N.1), l’integrato drive M.5450 convertirà i dati seriali applicati sugli ingressi in 
dati paralleli a 34 bit. Oltre a questi 34 bit l’integrato invia in uscita un bit di Start, uno di 
Load (carica dati) ed uno di Reset. 
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Fig.3 Per accendere il numero “1032”, sul primo display dovremo portare a livello logico 
1 i bit 2-3, sul secondo display i bit 9-10-11-12-13-14, sul terzo display i bit 17-18-19-20-23 
e sull’ultimo display i bit 25-26-28-29-31. Non confondete il livello logico del “bit” con quel¬ 
lo che apparirà sul piedino d’uscita che risulta invertito. 



Fig.4 Per pilotare un display LCD 
dovremo sempre portare a “livel¬ 
lo logico 1” i bit dei segmenti che 
vogliamo accendere, ma come 
potete vedere in fig.7 i segmenti 
che rimangono spenti non ven¬ 
gono portati a “livello logico 0”. 


























































I piedini d’uscita di questo integrato, come visibile 
in fig.5, indicati Al - B1 - CI, ecc., andranno col¬ 
legati ad ogni singolo segmento presente in cia¬ 
scun display (vedi fig.6 e Tabella N.2). 
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Anche in un display LCD se volessimo accende¬ 
re i numeri 1 0 3 2 tramite il programma softwa¬ 
re, dovremmo portare a livello logico 1 tutti i seg¬ 
menti che desideriamo accendere. 


Sul display N.1, dovendo accendere i segmenti B- 
C, dovremo portare a livello logico 1 i bit 2-3. 
Sul display N.2, dovendo accendere i segmenti A- 

B-C-D-E-F, dovremo portare a livello logico 1 i bit 
9-10-11-12-13-14. 

Sul display N.3, dovendo accendere i segmenti A- 
B-C-D-G, dovremo portare a livello logico 1 i bit 
17-18-19-20-23. 

Sul display N.4, dovendo accendere i segmenti A- 
B-G-E-D, dovremo portare a livello logico 1 i bit 
25-26-31-29-28. 

A questo punto si potrebbe pensare che un drive 
per pilotare un display a 7 segmenti possa servi¬ 
re anche per pilotare un display LCD, ma purtrop¬ 
po questo non è possibile perchè i suoi segmenti 
non vengono pilotati da una tensione continua, 
ma da un treno di onde quadre che lo stesso in¬ 
tegrato M.8438/AB6 invia al segmento da accen¬ 
dere, sfasandolo di 180° rispetto alle onde quadre 
che giungono sui segmenti che debbono rimanere 
spenti. 

Quindi se controllassimo con un oscilloscopio tutti 
i 32 piedini d’uscita di questo integrato, troverem¬ 
mo in tutti delle onde quadre, perciò potrebbe ri¬ 
sultare alquanto complesso capire come si riesca¬ 
no ad accendere questi segmenti. 

Per spiegarvelo in modo che possiate compren¬ 
derlo perfettamente vi proponiamo questo sempli¬ 
ce esempio. 

Ammesso di voler accendere in un display i seg¬ 
menti B-C in modo da far apparire il numero 1, in 
questi due soli segmenti giungeranno delle onde 
quadre invertite rispetto alle onde quadre che giun¬ 
gono invece sul Back/Plane (vedi fig.7). 

Di questa inversione del segnale ad onda quadra 
non dovremo preoccuparci, perchè sarà l’integrato 

M. 8438/AB6 che provvederà ad invertirlo quando, 
tramite software, gli diremo di accendere i segmenti 
B-C. 

Il software per i display LCD in pratica è molto si¬ 
milare a quello per i display a 7 segmenti, sempre 
che si rispettino le connessioni d’uscita dell’inte¬ 
grato M.8438/AB6 con i piedini che fanno capo ai 
segmenti dei quattro display (vedi Tabelle N.1 e 

N. 2). 

Nelle connessioni del display tipo S.5126 oppu¬ 
re LC.513040 riportate in fig.8, abbiamo indica¬ 
to con A1-B1-C1, ecc., tutti i segmenti del di¬ 
splay N.1, con A2-B2-C2, ecc., tutti i segmenti 
del display N.2 e così dicasi per il display N.3 e 
N.4. 

Se abbiamo un display con una sigla diversa, do- 
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Fig.5 Per pilotare 4 display LCD occorre un integrato drive tipo M.8438 o altri equivalen¬ 
ti. Dei tre piedini d’ingresso, quello indicato Strobe si porta a livello logico 1 quando de¬ 
ve caricare i dati, quelli indicati Data e Clock vengono utilizzati per ricevere i dati seriali 
e i segnali di sincronismo. Il display LCD viene alimentato direttamente dall’Integrato 
M.8438 tramite il piedino Back/Plane. 



Fig.6 Ogni bit corrisponde ad un singolo segmento di ogni display (vedi Tabella N.2) e 
per agevolarvi abbiamo riportato su ogni piedino dell’integrato M.8438 (vedi fig.5) sia il 
numero del bit sia quale segmento si accenderà sui display 1-2-3-4. 



























































































vremo controllare a quali piedini fanno capo i seg¬ 
menti A-B-C-D-E-F-G del primo, del secondo, del 
terzo e del quarto display, per collegarli in ordine 
ai piedini d’uscita dell’integrato drive. 


SCHEMA ELETTRICO 

Dopo avervi spiegato la differenza che esiste tra 
un display a 7 segmenti a led ed uno a LCD pos¬ 
siamo passare a presentarvi lo schema elettrico. 
Guardando la fig.9 è possibile notare che dal con¬ 
nettore siglato CONN. 1/2 preleviamo: 

- dal piedino BO i dati da inviare al piedino 34 dell’in¬ 
tegrato M.8438/AB6. 

- dal piedino B1 il segnale del Clock da inviare al 
piedino 40 di IC1. 

- dal piedino C4 il segnale di Strobe da inviare al 
piedino 2 di IC1. 

- dal piedino +5V la tensione di alimentazione per 
l’integrato. 

Gli altri due piedini B2-B3 sono collegati ai pulsanti 
P1-P2 che ci servono, realizzando un orologio, per 
mettere a punto le ore e i minuti. 

Poiché l’integrato M.8438/AB6 ha bisogno del se¬ 
gnale di Strobe, dovremo necessariamente utiliz¬ 
zare dei microprocessori ST6 con 28 piedini, cioè: 

ST62E25 (da 4K cancellabile) 

ST62T25 (da 4K non cancellabile) 

ST62T15 (da 2K non cancellabile) 
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Fig.7 Per accendere un segmento in un di¬ 
splay LCD l’integrato IC1 invierà sul piedi¬ 
no corrispondente un’onda quadra sfasata 
di 180° rispetto a quella del Back/Plane. 
In questo esempio risultano accesi i soli 
segmenti B-C. 


BACK/P FI B1 F2 B2 G3 A3 G4 A4 
| Gl | Al | G2 | A2 | DP41 F3 | B3 | F4 | 

■ in 11 iiiiiiiiiiii 11 ■ 



■11111Ifflllllllll111 

I E1 I CI I E2 I C2 I E3 I C3 I E4 I C4 I 

BACK/P DI DPI D2 DP2 D3 DP3 D4 B4 



Fig.8 Connessioni del display LCD. Su ogni terminale abbiamo riportato la lettera dei set¬ 
te segmenti A-B-C ecc. seguita dai numeri del display cioè 1-2-3-4. La tacca di riferimen¬ 
to è costituita da una “goccia” di vetro o dal segno “>” posto da un lato del corpo. 
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Fig.9 Schema elettrico da noi utilizzato per 
pilotare un display LCD. 


ELENCO COMPONENTI LX.1207 

RI = 10.000 ohm 1/4 watt 
R2 = 10.000 ohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 22 pF ceramico 
C3 = 100.000 pF poliestere 
C4 = 100.000 pF poliestere 
IC1 = M.8438-AB6 o M.8438-B6 
LCD = display LCD tipo S.5126 
CONN.1/2 = connettore 24 poli 
CONN. = 2 connettori 4 poli 
PI = pulsante 
P2 = pulsante 


Il motivo per il quale si è obbligati ad utilizzare dei 
micro ST6 a 28 piedini è dovuto al fatto che ci ser¬ 
ve la porta C4 per il segnale di Strobe. 

A questo punto qualcuno ci potrà far osservare che 
il segnale di Strobe potevamo benissimo prelevarlo 
da una bit libero della porta A oppure B e, in tal 
modo, potevamo ancora utilizzare un micro ST6 
con soli 20 piedini. 

Purtroppo nel bus siglato LX.1202 (vedi rivista 
N.179) se oltre alla scheda di questo display vo¬ 
lessimo inserire anche la scheda LX.1205 che pi¬ 
lota dei relè, oppure la scheda LX.1206 che pilota 
dei triac, constateremmo che tutti i bit delle porte 
A-B risultano occupati. 

Poiché in questa scheda utilizziamo anche la por¬ 
ta C, il programma che vi forniremo per questo di¬ 
splay LCD sarà completamente diverso rispetto al 
software che vi avevamo già fornito per la scheda 
display LX.1204 e questo potrà risultarvi molto uti¬ 
le perchè, confrontando i due programmi, potrete 
notare le differenze. 

Comunque questo programma per display LCD 
svolgerà le stesse funzioni che svolge tutt’ora il pro¬ 
gramma per il display a 7 segmenti. 












































CDNM, 1/2 HTfffb\© fc_& J> Ì&3i Li! 


Fig.10 Scheda vista 
dal lato del display. 


Fig.11 Circuito stam¬ 
pato visto dal lato 
dell’integrato. 
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Ritornando al nostro schema elettrico, non dovre¬ 
te preoccuparvi delle connessioni dell’integrato IC1 
con il display LCD, perchè queste vengono auto¬ 
maticamente effettuate tramite le piste in rame pre¬ 
senti sul circuito stampato. 

In questo schema di critico c’è il solo condensato- 
re C2 collegato tra il piedino 31 e la massa. 
Questo condensatore, come potrete leggere nell’e¬ 
lenco componenti, deve risultare da 22 picoFarad 
e tale valore serve per generare, tramite uno sta¬ 
dio oscillatore interno, una frequenza di circa 
20.500 Hz che, divisa internamente per 256, farà 
uscire dal piedino 30 di IC1 un’onda quadra di cir¬ 
ca 80 Hz. 

Questa frequenza chiamata Back/Plane, è quella 
che ci servirà per alimentare i piedini 1-40 del di¬ 
splay LCD. 


REALIZZAZIONE PRATICA 

Realizzare questa scheda per display LCD che ab¬ 
biamo siglato LX.1207 è molto semplice. 

Nel circuito stampato a doppia faccia con fori me¬ 
tallizzati dovrete inserire tutti i componenti richiesti 
e per iniziare vi consigliamo di saldare lo zoccolo 
per l’integrato IC1. 

Dopo aver saldato tutti i piedini sulle piste dello 
stampato, potrete inserire i due connettori maschi 
da 4 piedini e da 24 piedini, che vi serviranno per 
innestare questa scheda nel bus siglato LX.1202 
(vedi rivista N.179). 

Terminata questa operazione, capovolgete lo stam¬ 
pato e da questo lato inserite i due connettori fem¬ 
mina da 20 piedini che vi serviranno come zocco¬ 
lo per il display LCD. 












































Fig.12 La scheda del display LCD siglata LX.1207 andrà inserita nel Bus LX.1202 con¬ 
giunta anche alla scheda dei Relè o dei Triac. Come microprocessore ST6 dovrete ne¬ 
cessariamente utilizzare quelli a 28 piedini, cioè rST62.E25 che è riprogrammabile o i ti¬ 
pi ST62.T15 e ST62.T25 che non sono riprogrammabili. 


























Per completare il montaggio dovrete inserire le re¬ 
sistenze R1-R2, i due pulsanti P1-P2, i tre con¬ 
densatori poliestere ed il ceramico da 22 picoFa- 
rad ed innestare nello zoccolo l’integrato 
M.8438/AB6, orientando la tacca a forma di U im¬ 
pressa sul suo corpo come visibile nella fig.10. 

Dal lato opposto dovrete inserire nei due connet¬ 
tori femmina tutti i piedini presenti nel display LCD 
e qui forse incontrerete qualche difficoltà, perchè 
spesso i piedini del display risultano troppo divari¬ 
cati. 

Per poterli restringere in modo uniforme potrete 
premere sul piano di un tavolo tutti i terminali. 
Prima di inserire il display nei connettori, dovrete 
ricercare sul suo corpo la tacca di riferimento, per¬ 
chè se lo inserirete in senso inverso non potrà fun¬ 
zionare. 

In questi display questa tacca di riferimento non è 
molto visibile, perchè quasi sempre è costituita da 
una piccola goccia di vetro posta su una sola e- 
stremità. 

Da questo stesso lato troverete spesso sulla cor¬ 
nice nera che contorna l’interno del display il se¬ 
gno > (vedi fig.8). 

Questa tacca di riferimento va sempre rivolta ver¬ 
so i condensatori C1-C2. 

Spingete il display in corrispondenza dei lati in cui 
sono presenti i terminali e mai del centro perchè 
potrebbe spezzarsi. 


PROGRAMMI 

Per far funzionare questa scheda display LCD ab¬ 
biamo preparato 5 programmi che troverete inse¬ 
riti in un dischetto floppy da 3 pollici siglato 

DF1207.3. 

Una volta in possesso del dischetto, per caricarlo 
nell’Hard-Disk dovrete procedere come di seguito 
spiegato. 

Uscite da qualsiasi programma che stavate utiliz¬ 
zando, Windows - Pcshell - Norton ecc., e quan¬ 
do sul monitor del computer appare C:\> inserite il 
dischetto nel drive A, quindi digitate: 

C:\>A poi premete Enter 

Quando appare A:\> scrivete: 

A:\>installa e premete Enter 

Il programma vi chiederà subito in quale directory 
volete installare il contenuto del disco. 

Noi abbiamo già definito una directory che abbia¬ 
mo chiamato LX1207, quindi se premete Enter il 



Fig.13 Quando sul monitor appare la fine¬ 
stra dell’Editor potete premere i tasti ALT+F 
poi F3 e vedrete apparire tutti i files con l’e¬ 
stensione .ASM. 



Fig.14 Nel nuovo dischetto LX1207 non tro¬ 
verete nessuno dei vecchi programmi (ve¬ 
di foto), ma i soli programmi da utilizzare 
per questa scheda con display LCD. 
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Fig.15 Potrete trasferire il programma scel¬ 
to nella memoria di un ST6 solo dopo averlo 
assemblato. Per assemblarlo dovrete pre¬ 
mere i tasti ALT+T poi Enter. 

































programma creerà automaticamente una directory 
con questo nome e, scompattandolo, copierà il 
contenuto del dischetto all’interno dell’Hard-Disk. 
Se sul monitor dovesse apparire la scritta error, 
potrete ricaricare il dischetto con questo diverso si¬ 
stema. 

Quando appare C:\> dovrete creare la directory 
scrivendo: 

C:\>MD LX1207 poi premete Enter 

Quando riapparirà il prompt di C:\> inserite il di¬ 
schetto floppy nel drive A poi scrivete: 

C:\>COPY A:*.* C:\LX1207 poi premete Enter 

Nota = Poiché nella digitazione è necessario ri¬ 
spettare la spaziatura, per agevolarvi abbiamo in¬ 
terposto una barra in colore che corrisponde allo 
spazio che occorre lasciare tra le lettere. 

Quando il computer avrà terminato di copiare dal 
dischetto tutti i programmi, questi non saranno an¬ 
cora stati scompattati quindi dovrete farlo voi scri¬ 
vendo: 

CD:\>CD LX1207 poi premete Enter 

Quando appare C:\LX1 207> digitate: 

C:\LX1 207>installa poi premete Enter 

In questo modo vedrete via via comparire sul mo¬ 
nitor i nomi dei files che si stanno scompattando. 


CONVERTIRE i files .ASM in .HEX 

Prima di trasferire un file nella memoria di un ST6 
occorre, come abbiamo precisato nei precedenti 
numeri, assemblarlo in modo da ottenere un se¬ 
condo ed identico file, ma con l’estensione .HEX. 
Se tenterete di trasferire un file .ASM nella memo¬ 
ria del micro vi verrà segnalato error. 

Il micro da usare per i display LCD deve necessa¬ 
riamente avere 28 piedini, quindi potrete adopera¬ 
re un ST62.E25 se volete riprogrammarlo e cancel¬ 
larlo più volte, oppure un ST62.T15 o un ST62.T25 
che come sapete non sono cancellabili. 

Anche se nei precedenti articoli vi abbiamo spie¬ 
gato come procedere per trasformare un file .ASM 
in un file .HEX, lo ripeteremo nuovamente. 

Quando sul monitor appare C:\LX1 207> dovete 
scrivere: 


C:\LX1 207>ST6 poi premere Enter 

Con questo comando apparirà la finestra dell’Edi- 
tor (vedi fig.13). 

A questo punto dovrete premere prima i tasti 
ALT+F poi il tasto F3 e sul monitor vedrete ap¬ 
parire tutti i files con estensione .ASM (vedi 
fig.i 4). 

LCDCLOCK.ASM 

LCDCRONO.ASM 

LCDOROLO.ASM 

LCDTEM90.ASM 

LCDTIM90.ASM 

Per posizionare il cursore su uno dei cinque files 
premete ALT+F poi premete i tasti freccia giù/su e 
quando sarete sul file che vi interessa premete En¬ 
ter. 

Entrerete così nell’editor del file selezionato e a- 
vrete in linea le istruzioni del programma. 

Per assemblare il programma dovete premere i ta¬ 
sti ALT+T e poi Enter (vedi fig.15). 

Ammesso che abbiate scelto il file LCDCLOCK, do¬ 
po pochi secondi apparirà sul monitor la scritta: 


con il tempo di compilazione e di seguito la scritta: 

C:\LX1 207> 

Premendo Enter rientrerete nel programma LCD¬ 
CLOCK. 

Per uscire dovrete premere ALT+F3. 

Vedrete nuovamente la maschera dell’Editor e a 
questo punto premendo i tasti: 

ALT+F poi F3 poi Enter 

apparirà nuovamente la maschera di tutti i files con 
estensione .ASM. 

Nella riga in alto dovrete sostituire la scritta .ASM 
con la scritta .HEX poi premere Enter. 

In questo modo apparirà l’elenco dei files conver¬ 
titi in .HEX, e poiché è stato convertito il solo file 
LCDCLOCK comparirà: 

LCDCLOCK.HEX 

Vi ricordiamo che per modificare le righe di un pro¬ 
gramma dovrete sempre lavorare nell’estensione 
.ASM. Dopo aver fatto le modifiche le dovrete sal¬ 
vare premendo il tasto F2, poi dovrete assembla¬ 
re il programma per convertirlo in un file .HEX co¬ 
me poc’anzi vi abbiamo spiegato. 


I 5 programmi che abbiamo inserito in questo di¬ 
schetto hanno le stesse funzioni dei programmi che 
vi abbiamo presentato per i display a 7 segmenti, 
ma sono stati riscritti e adattati per pilotare in se¬ 
riale l’integrato M.8438/B6, quindi le righe che po¬ 
trete modificare hanno un diverso numero. 


LCDCRONO.HEX 

Questo programma è un semplice cronometro, 
quindi per visualizzare i tempi occorre inserire nel 
bus LX.1202 la sola scheda dei display siglata 

LX.1207. 

Se nel bus inserirete le schede dei relè o dei triac, 
non potrete renderle attive perchè nel programma 
non è presente nessuna istruzione per gestirle. 
Una volta caricato su un micro ST62.E25 ripro¬ 
grammabile vergine il programma LCDCRO¬ 
NO.HEX ed inserito nello zoccolo presente sulla 
scheda bus LX.1207, appena alimenterete il cir¬ 
cuito sui 4 display apparirà il numero: 

00:00 

Premendo il pulsante PI il micro comincerà a con¬ 
tare in avanti ad intervalli di tempo di un secondo, 
quindi sui display vedrete apparire i numeri: 

00:01 - 00:02 - 00:03 ecc. 

Sui primi due display di sinistra vedrete i minuti e 
sui display di destra i secondi. 

I due punti che separano i display dei minuti e dei 
secondi lampeggeranno con una cadenza di un se¬ 
condo. 

Come noterete, quando si è raggiunto un tempo di 
00:59 secondi, subito dopo si passerà al tempo 
successivo di 01:00, cioè 1 minuto e 00 secondi. 

II massimo numero che potrete visualizzare sarà 
quindi di 99 minuti e 59 secondi, dopodiché ap¬ 
parirà 00:00. 

Se in fase di conteggio premerete PI, il conteggio 
si bloccherà sul tempo raggiunto e premendolo 
nuovamente ripartirà dal numero sul quale si era 
fermato. 

Se invece premerete il pulsante P2, il conteggio ri¬ 
partirà da zero, cioè il tempo visualizzato si azze¬ 
rerà. 


LCDOROLO.HEX 

Questo programma è un semplice orologio. 

Per poter visualizzare le ore ed i minuti dovrete 


inserire nel bus LX.1202 la sola scheda dei display 
siglata LX.1207. 

Se nel bus inserirete le schede dei relè o dei triac, 
non potrete renderle attive, perchè nel program¬ 
ma non è presente nessuna istruzione per gestir¬ 
le. 

Una volta caricato su un micro ST6 vergine il pro¬ 
gramma LCDOROLO.HEX ed inserito nello zoc¬ 
colo presente nella scheda bus LX.1202, non ap¬ 
pena alimenterete il circuito sui 4 display apparirà 
il numero: 

00:00 

I primi due display di sinistra segneranno le ore, 
mentre i due di destra i minuti. 

I due punti che separano i due display lampegge¬ 
ranno con una cadenza di 1 secondo. 

Come noterete, raggiunte le ore 23 ed i 59 minu¬ 
ti, dopo 1 minuto si passerà alle 24 ore che ver¬ 
ranno visualizzate con 00:00. 

Per mettere a punto le ore dell’orologio si utiliz¬ 
zerà il pulsante P2 e, per mettere a punto i minu¬ 
ti, il pulsante PI. 

Facciamo presente che potrete solo far avanzare 
i numeri e non indietreggiare. 


LCDCLOCK.HEX 

Questo programma è totalmente diverso dal pre¬ 
cedente programma LCDOROLO, perchè oltre a 
visualizzare le ore e i minuti permette di eccitare 
un relè o un triac ad un’ora prestabilita e di di¬ 
seccitarlo dopo un tempo che voi stessi potrete 
prefissare modificando alcune righe del program¬ 
ma. 

Per farlo funzionare occorre inserire nel bus 
LX.1202 la scheda dei display siglata LX.1207 e 
quella dei relè siglata LX.1205, oppure quella dei 
triac siglata LX.1206. 

Prima di spiegarvi quali righe dovrete modificare, 
consigliamo ai meno esperti di leggere attenta¬ 
mente tutto l’articolo, dopodiché potranno modifi¬ 
care i parametri nelle sole righe che noi indiche¬ 
remo. 

Come abbiamo accennato, il programma LCD¬ 
CLOCK.HEX ci dà la possibilità di eccitare o di¬ 
seccitare uno o più relè anche contemporanea¬ 
mente, su orari che noi stessi potremo stabilire, pur¬ 
ché non si superino più di 8 cicli o periodi nell’ar¬ 
co delle 24 ore. 

Questo programma potrà servire per accendere o 
spegnere una o più caldaie, delle insegne lumino¬ 
se ad orari prestabiliti, ecc. 


Per mettere a punto le ore dell’orologio si utiliz¬ 
zerà il pulsante P2 e per mettere a punto i minuti 
il pulsante PI. 

Facciamo presente che è possibile soltanto far a- 
vanzare i numeri e non indietreggiare. 

Appena accenderete l’orologio tutti i 4 relè o triac 
partiranno eccitati. 

Se volete che all’accensione dell’orologio tutti i relè 
risultino diseccitati, dovrete andare alla riga N.57 
dove troverete questa istruzione: 

Idi portb.l 1110011 b 

e modificarla inserendo in sostituzione degli 1 de¬ 
gli 0 come qui sotto riportato: 

Idi portb,00000011 b 

Nota = Anche se questa riga è composta da 8 nu¬ 
meri, dovrete modificare solo i primi 4 di sinistra. 

Se volete far eccitare all’accensione il solo relè 
RL4, dovrete mettere un 1 in corrispondenza del¬ 
la prima cifra di sinistra come qui sotto riportato: 

Idi port_b,10000011 

A questo punto vi spieghiamo che cosa s’intende 
per 8 cicli o periodi da utilizzare nell’arco delle 24 
ore che troverete riportati in queste righe: 

1 ° periodo = righe 299 - 300 - 301 
2° periodo = righe 306 - 307 - 308 
3° periodo = righe 313 - 314 - 315 
4° periodo = righe 320 - 321 - 322 
5° periodo = righe 327 - 328 - 329 
6° periodo = righe 334 - 335 - 336 
7° periodo = righe 341 - 342 - 343 
8° periodo = righe 348 - 349 - 350 

Ogni ciclo è composto da 3 righe d’istruzioni, quin¬ 
di nel 1 ° ciclo o periodo del nostro programma tro¬ 
verete: 


.byte 

02 

; 299 riga delle ore 

.byte 

30 

;300 riga dei minuti 

.byte 

lllOOOOOb 

;301 riga per comando relè 


Attualmente il 1 0 ciclo inizia alle ore 2,30 di not¬ 
te. 

Per modificare l’orario basterà mettere nella prima 
riga l’ora che vi interessa, ad esempio 05-06-10, e 
nella seconda riga i relativi minuti, ad esempio 00 

- 10-30-50. 

Nella terza riga sono riportati i relè che desiderate 
eccitare e quelli che non desiderate eccitare all’o¬ 
rario da noi prestabilito. 



Fig.16 Dopo aver assemblato il programma 
prescelto (vedi fig.15) pigiate ALT+T poi la 
lettera P. Quando apparirà questa finestra 
dovrete premere un tasto qualsiasi. 



Fig.17 Come vedrete, sullo schermo appa¬ 
rirà una finestra con tutti i tipi di ST62. Con 
i tasti freccia ricercate la sigla ST62E25 poi 
pigiate il tasto Enter. 



Fig.18 Prima di programmare l’ST62E25 
controllate attentamente che nel riquadro in 
basso appaia ST62E25. Se appare un’altra 
sigla dovrete ritornare alla fig.17. 






























Mettendo un 1 il relè si ecciterà, mettendo uno 0 

si disecciterà. 

Ciò che dovrete modificare in questa terza riga so¬ 
no solo i primi quattro numeri di sinistra posti do¬ 
po la parola byte. 

Tenete presente che il primo numero di sinistra pi¬ 
loterà il relè RL4 e l’ultimo numero di destra il relè 
RL1, quindi avrete in ordine: 

RL4-RL3-RL2-RL1 

Per farvi capire come modificare tutti questi nume¬ 
ri vi faremo un semplice esempio. 

Ammesso che alle 06,10 desideriate eccitare i relè 
RL2-RL1 , scriverete nelle righe 299 - 300 - 301 (1 ° 
ciclo) questi numeri: 


.byte 

06 

;299 riga delle ore 

.byte 

10 

;300 riga dei minuti 

.byte 

OOllOOOOb 

;301 riga per comando relè 


Se alle 09,30 vorrete eccitare il solo relè RL4, do¬ 
vrete scrivere nelle righe 306 - 307 - 308 (2° ciclo) 
questi numeri: 

.byte 09 ;306 riga delle ore 

.byte 30 ;307 riga dei minuti 

.byte lOOOOOOOb ; 308 riga per comando relè 

Se alle 12,00 vorrete diseccitare anche il relè RL4, 
dovrete scrivere nelle righe 313 -314 -315 (3° ci¬ 
clo) questi numeri: 


.byte 

12 

;313 riga delle ore 

.byte 

00 

;314 riga dei minuti 

.byte 

OOOOOOOOb 

;315 riga per comando relè 


Se alle 18,45 vorrete eccitare tutti i relè, dovrete 
scrivere nelle righe 320 - 321 - 322 (4° ciclo) que¬ 
sti numeri: 


.byte 18 

;320 riga delle ore 

.byte 45 

;321 riga dei minuti 

.byte llllOOOOb 

;322 riga per comando relè 

Se alle 22,30 vorrete 
dovrete scrivere nelle 
ciò) questi numeri: 

diseccitare i relè RL4-RL3, 
righe 327 - 328- 329 (5° ci- 

.byte 22 

;327 riga delle ore 

.byte 30 

;328 riga dei minuti 

.byte OOllOOOOb 

;329 riga per comando relè 

Se alle 23,40 vorrete 

lasciare eccitato il solo relè 


RL1 , dovrete scrivere nelle righe 334 - 335 - 336 
(6° ciclo) questi numeri: 


.byte 

23 

;334 riga delle ore 

.byte 

40 

;335 riga dei minuti 

.byte 

OOOIOOOOb 

;336 riga per comando relè 


Se alle 24,00 vorrete diseccitare anche questo 
relè, dovrete scrivere nelle righe 341 - 342 - 343 
(7° ciclo) questi numeri: 


.byte 

00 

;341 riga delle ore 

.byte 

00 

;342 riga dei minuti 

.byte 

OOOOOOOOb 

;343 riga per comando relè 


Avendo utilizzato solo 7 cicli degli 8 disponibili, se 
l’ultimo non vi interessa lo potrete cancellare op¬ 
pure inibire, mettendo davanti alle righe 348 - 349 
- 350 un punto e virgola o mettendo sulla terza ri¬ 
ga OOOOOOOOb. 

Potrete aggiungere altri cicli se 8 risultassero in¬ 
sufficienti. 

Facciamo presente che questi cicli si ripeteranno 
automaticamente all’infinito agli stessi orari tutti i 
giorni. 


LCDTIM90.HEX 

Questo programma è un timer che, contando in a- 
vanti, ecciterà un relè o un triac quando raggiun¬ 
gerà i minuti e i secondi da noi prefissati. 

Per farlo funzionare occorre inserire nel bus 
LX.1202 la scheda dei display LCD siglata LX.1207 
e quella dei relè siglata LX.1205, oppure quella dei 
triac siglata LX.1206. 

Non appena alimenterete il circuito, il conteggio 
partirà da 00:00 e inizierà a contare in avanti; a 
questo punto potrete utilizzare i pulsanti PI e P2 
presenti sulla scheda display LCD LX.1207. 

Premendo PI il conteggio si ferma. 

Premendo nuovamente PI il conteggio riparte dal 
numero sul quale si era fermato. 

Premendo P2 il contatore si resetta. 

Premendo PI il contatore riparte da 00:00. 

Nota = Il pulsante P2 di reset sarà attivo solamente 
se avrete fermato il conteggio con PI. Se preme¬ 
rete P2 mentre è attivo il conteggio, questo non si 
azzererà. 

I pulsanti presenti sulle schede Triac e Relè non ri¬ 
sultano attivati. 

II conteggio del display arriva ad un massimo di 89 

minuti e 59 secondi. 

Il programma LCDTIM90.ASM, come potrete no- 


tare, dispone di 4 cicli perchè quattro sono i relè 
e i triac presenti sulle schede sperimentali. 

1 ° ciclo = Dopo 20 secondi dall’accensione si ec¬ 
citerà il solo relè RL1. 

Ovviamente sui display vedrete apparire 19 e, 
quando questo numero raggiungerà 00:00, il relè 
si ecciterà. 

2“ciclo = Passando al secondo ciclo, questo relè 
rimarrà eccitato per un tempo da noi prefissato in 

I minuto e 30 secondi e raggiunto questo tempo 
il relè RL1 si disecciterà e automaticamente si ec¬ 
citerà il relè RL2. 

II relè RL2 si ecciterà un secondo dopo che sui di¬ 
splay sarà apparso il numero 01:29 che cambierà 

in 00:00. 

3° ciclo = Dopo 47 secondi, cioè quando sul di¬ 
splay il numero 46 passerà sullo 00, il relè RL2 si 

disecciterà e si ecciterà il terzo relè RL3. 

4° ciclo = Il conteggio continuerà ed allo scoccare 
dei 3 minuti e 00 secondi (tempo da noi prefis¬ 
sato) si disecciterà il relè RL3 e si ecciterà il relè 
RL4, cioè si ritornerà al 1 0 ciclo per ripetere all’in¬ 
finito i quattro cicli. 

Per variare i tempi che noi abbiamo prefissato do¬ 
vrete variare queste righe: 

1 ° ciclo = righe 292 - 293 
2° ciclo = righe 298 - 299 
3° ciclo = righe 304 - 305 
4° ciclo = righe 310 - 311 


Se volete che il 1 0 ciclo abbia una durata di 1 mi¬ 
nuto e 30 secondi, dovrete inserire nelle sue ri¬ 
ghe questi numeri: 


Idi 

stsex,30 

;292 secondi per RL1 

Idi 

stmix,1 

; 293 minuti per RL1 

Se volete che il 2° 

ciclo abbia una durata di 50 se- 

condi, dovrete inserire nelle sue righe questi numeri: 

Idi 

stsex,50 

;298 secondi per RL1 


Idi stmix,00 ;299 minuti per RL1 

Se volete che il 3°ciclo abbia una durata di 15 mi¬ 
nuti e 20 secondi, dovrete inserire nelle sue righe 
questi numeri: 

Idi stsex,20 ;304 secondi per RL1 

Idi stmix,15 ;305 minuti per RL1 

Se volete che il 4° ciclo abbia una durata di 2 mi¬ 


nuti e 10 secondi, dovrete inserire nelle sue righe 
questi numeri: 

Idi stsex,10 ;310 secondi per RL1 

Idi stmix,2 ;311 minuti per RL1 

Nelle righe 295/296 - 301/302 - 307/308 - 313/314 

sono riportate le sigle dei relè che volete eccitare 
e di quelli che volete rimangano diseccitati. 
Guardando l’esempio riportato nel programma 
LCDCLOCK.ASM saprete già che scrivendo que¬ 
sta istruzione: 

Idi port_b,11110011b 

potrete eccitare ad ogni ciclo anche più relè a vo¬ 
stra scelta. 

Nei primi quattro numeri di sinistra (vedi 1111) do¬ 
vrete mettere un 1 sul relè che volete far eccitare 
ed uno 0 se non lo volete eccitare. 


LCDTEM90.HEX 

Questo programma è un timer che fa esattamen¬ 
te l’inverso del programma LCDTIM90, cioè con¬ 
ta all’indietro e quando raggiunge lo 00:00 eccita 
i relè. 

I relè, come per il programma precedente, li ecci¬ 
terete in 4 cicli e come tempo massimo di par¬ 
tenza potrete impostare 90 minuti e 00 secondi. 
Non appena alimenterete il circuito, il conteggio 
partirà da 00:20 (questo tempo lo abbiamo pre¬ 
scelto noi, ma poi vi spiegheremo come modificar¬ 
lo) e procederà all’indietro. 

Dopo che avrà avuto inizio il conteggio, potrete u- 
tilizzare i pulsanti PI e P2 presenti sulla scheda di¬ 
splay LCD LX.1207. 

Premendo PI il conteggio si ferma. 

Premendo nuovamente PI il conteggio riparte dal 
numero sul quale si era fermato. 

Premendo P2 il contatore si resetta. 

Premendo PI il contatore riparte dal tempo che a- 
vete impostato come partenza per il conteggio 
all’indietro. 


Nota = Il pulsante P2 di reset sarà attivo solamente 
se avrete fermato il conteggio con PI . Se preme¬ 
rete P2 mentre è attivo il conteggio, questo non si 
azzererà. Premendo P2 per resettarlo, è intuitivo 
che contando all’indietro sul display ritorni il tem¬ 
po di partenza, cioè 00:20. 


Nei 4 cicli impostati otterrete queste condizioni: 


1 “ciclo = All’accensione si ecciterà il solo relè RL1 
e sui display apparirà 00:20 e a questo punto avrà 
inizio il conteggio alla rovescia che si fermerà sul¬ 
lo 00:00. 

2° ciclo = Dopo un secondo si ecciterà il relè RL2 
e a questo punto inizierà il secondo ciclo, che farà 
apparire sui display 01:30 (tempo 1 minuto e 30 
secondi) che, secondo per secondo, decremen- 
terà fino ad arrivare a 00:00. 

3° ciclo = A questo punto si ecciterà il relè RL3 e 
sui display apparirà 00:47 che decrementerà fino 
ad arrivare allo 00:00. 

4° ciclo = L’ultimo ciclo farà eccitare il relè RL4 e 
farà apparire sui display il numero 03:00 (3 minu¬ 
ti). Quando con il conteggio alla rovescia si arri¬ 
verà al numero 00:00, questo relè si disecciterà e 
contemporaneamente si disecciterà il relè RL1, 
cioè si ritornerà al 1° ciclo per ripetere all’infinito i 
quattro cicli. 

Per variare i tempi prefissati dovrete modificare 
queste righe: 

1 ° ciclo = righe 295 - 296 
2° ciclo = righe 301 - 302 
3° ciclo = righe 307 - 308 
4° ciclo = righe 313 - 314 

Se volete che il 1 0 ciclo abbia una durata di 1 mi¬ 
nuto e 30 secondi, dovrete inserire nelle sue ri¬ 
ghe questi numeri: 

Idi stsex,30 ; 295 secondi per RL1 

Idi stmix,1 ; 296 minuti per RL1 

Se volete che il 2° ciclo abbia una durata di 50 se¬ 
condi, dovrete inserire nelle sue righe questi nu¬ 
meri: 

Idi stsex,50 ; 301 secondi per RL1 

Idi stmix,00 ; 302 minuti per RL1 

Se volete che il 3° ciclo abbia una durata di 15 mi¬ 
nuti e 20 secondi, dovrete inserire nelle sue righe 
questi numeri: 


Idi 

stsex,20 

;307 secondi per RL1 

Idi 

stmix,15 

;308 minuti per RL1 


Se volete che il 4° ciclo abbia una durata di 2 mi¬ 
nuti e 10 secondi, dovrete inserire nelle sue righe 
questi numeri: 

Idi stsex,10 ; 313 secondi per RL1 

Idi stmix,2 ;314 minuti per RL1 

Nelle righe 297/298 - 303/304 - 309/310 - 315/316 

sono riportate le sigle dei relè che si ecciteranno 
e di quelli che si disecciteranno. 

Anche in questo programma possiamo sostituire le 
righe sopra menzionate con questa sola riga d’i¬ 
struzione: 

Idi port-bjllllOOIIb 

Nei primi quattro numeri di sinistra (vedi 1111) do¬ 
ve metterete 1 il relè si ecciterà, dove metterete 0 

si disecciterà. 


NOTA 

Per imparare a programmare i microprocessori ST6 
vi consigliamo di rileggere tutti i precedenti articoli 
riportati sulle riviste N.172/173 - 174 - 175/176 - 
179 - 180, perché da oggi in avanti non ripeteremo 
più quello che vi abbiamo già spiegato. 

Sul prossimo numero vi presenteremo un progetto 
completo dei relativi programmi per gestire un di¬ 
splay LCD ALFANUMERICO a più righe, quindi 
proseguiremo spiegandovi come si dovrà proce¬ 
dere per ottenere dei programmi sempre più per¬ 
fetti e funzionali. 


KIT ESAURITO 

perché l’integrato M.8438/AB6 
è fuori produzione 


COSTO DI REALIZZAZIONE 

Tutti i componenti per realizzare questa scheda 
con display LCD, cioè circuito stampato, connet¬ 
tori maschi, pulsanti, integrato M.8438/AB6, di¬ 
splay a cristalli liquidi tipo S.5126 o LC.513040 
(escluso il solo software inserito nel dischetto 

DF.1207/3) .L.58.000 

Costo del solo stampato LX.1207 .L.9.000 

Nota = Per far funzionare questa scheda vi servo¬ 
no i 5 programmi inseriti nel dischetto siglato 
DF.1207/3 del costo di.L.12.000 




Se guardiamo il lato posteriore di un normale LCD 
vedremo il vetro del suo supporto, se guardiamo 
quello di un LCD alfanumerico vedremo un cir¬ 
cuito stampato con sopra fissati due integrati in 
SMD provvisti di 62-80 piedini (vedi fig.2). 

Se potessimo osservare anteriormente l’interno di 
un normale LCD vedremmo quattro caselle con i 
soliti 7 segmenti che, accendendosi, ci permetto¬ 
no di far apparire un numero qualsiasi da 0 a 9. 
Poiché questo Display può visualizzare solo dei nu¬ 
meri viene definito numerico. 

Se si potesse osservare, sempre anteriormente, 
l’interno di un Display alfanumerico, si vedrebbe¬ 
ro tante caselle rettangolari che, anziché essere 
composte da 7 segmenti, presentano ben 40 pun- 


con 1-2-3 righe, ecc., anche se nel nostro caso ne 
abbiamo scelto uno con 16 caratteri 2 righe per 
spiegarvi come si possa scrivere nella riga supe¬ 
riore ed in quella inferiore. 

La definizione 16 caratteri sta ad indicare che vi 
sono 16 caselle per riga, quindi avendo scelto un 
Display con 2 righe avremo un totale di 32 casel¬ 
le e poiché in ciascuna vi sono 40 punti potremo 
accendere ben: 

40 x 32 = 1.280 punti 

Ammesso di voler visualizzare su un normale Di¬ 
splay a 7 segmenti il numero 3, potremo risolvere 
il problema con estrema facilità alimentando i soli 


UNA SCHEDA per pilotare 


ti distribuiti 8 in senso verticale e 5 in senso oriz¬ 
zontale (vedi fig.3). 

Questi Display, conosciuti anche con il nome di 
DMLCD (vale a dire Dot Matrix Liquid Cristal Di¬ 
splay che in italiano significa Display a Cristalli Li¬ 
quidi con Matrice di Punti), sono chiamati alfanu¬ 
merici. 

Infatti, accendendo questi 40 punti nelle varie com¬ 
binazioni, potremo far apparire un qualsiasi carat¬ 
tere alfabetico maiuscolo o minuscolo, tutti i nu¬ 
meri da 0 a 9, un qualsiasi simbolo grafico, co¬ 
me ad esempio frecce, J , £2, n e, volendo, an¬ 
che caratteri cinesi - arabi - greci - cirillici, ecc. 
Questi display alfanumerici li possiamo reperire 


segmenti a-b-g-c-d, ma in un Display a matrice 
composto da 40 punti le cose diverrebbero ben più 
complesse perché dovremmo alimentare, nella pri¬ 
ma riga superiore i 5 punti in orizzontale, nella se- 
conda-terza-quarta-quinta riga 1 punto nella posi¬ 
zione richiesta, nella sesta riga 2 punti, uno all’i¬ 
nizio della riga ed uno alla fine e nella settima riga 
3 punti centrali. 

Immaginatevi quindi quanto sarebbe complicato 
scrivere nelle 32 caselle delle frasi o dei numeri. 
In teoria lo si potrebbe fare con un microproces¬ 
sore da 1.280 bit, ma poiché non esiste, vi chie¬ 
derete come si possano scrivere in tutte queste ca¬ 
selle lettere - numeri - simboli. 



Fig.1 Le dimensioni di un display 
alfanumerico (vedi a sinistra) so¬ 
no nettamente superiori a quelle 
del display numerico riprodotto a 
destra. 


Fig.2 Dal lato opposto del solo di¬ 
splay alfanumerico è presente un 
micro HD.44780 piu’ un integrato 
siglato HD.44100. 
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un DISPLAY alfanumerico 


Oltre ai normali display LCD a 7 segmenti presentati nella rivista N.181, 
in grado di visualizzare “4 numeri”, esistono anche dei display LCD “al¬ 
fanumerici” in grado di riprodurre un qualsiasi carattere grafico. In que¬ 
sto articolo vi spiegheremo come dovrete pilotarli per poter far appari¬ 
re parole - numeri - simboli. 


Per questi Display alfanumerici si sfrutta la stes¬ 
sa tecnica utilizzata per far apparire sul monitor 
del vostro computer tutte le lettere e i numeri pre¬ 
senti sulla tastiera. 

Quando sulla tastiera digitiamo la lettera A ge¬ 
neriamo un codice che, entrando in un integrato 
generatore di caratteri, viene trasformato in un 
codice ASCII che provvede a far accendere sul 
monitor tutti i punti richiesti per creare il simbo¬ 
lo A. 

Lo stesso avviene in questi Display, i quali vengo¬ 
no gestiti da un codice di 8 bit che, applicato sui 
piedini DBO - DB1 - DB2 - DB3 - DB4 - DB5 - DB6 

- DB7 (piedini dal numero 7 al numero 14), entrerà 
negli ingressi del microprocessore siglato 
HD.44780 (presente sul retro del display) al cui in¬ 
terno è presente una CGROM. 

La parola CGROM significa Characters Generator 
Read Only Memory, cioè lista di caratteri già me¬ 
morizzati al suo interno. 

AH’interno di questa CGROM sono memorizzate tut¬ 
te le lettere e i simboli visibili nella Tabella N . 1, 
quindi, se sui suoi piedini d’ingresso faremo giun¬ 
gere un codice composto da livelli logici 0-1, se¬ 
lezioneremo nella sua memoria la lettera o il sim¬ 
bolo abbinati a questo codice; per poter accende¬ 


re tutti i punti necessari per far apparire sul Display 
la lettera o il simbolo da noi prescelti, il micropro¬ 
cessore HD.44780 attenderà una conferma dal se¬ 
condo integrato siglato HD.44100. 

Detto questo, molti potrebbero pensare che sia suf¬ 
ficiente applicare sui piedini DBO - DB1 - DB2 - 
DB3 - DB4 - DB5 - DB6 - DB7 dei livelli logici 1-0 
per far apparire una lettera o un numero. 

Chi tentasse di farlo non vedrebbe accendersi 
nessun punto, perché i due integrati HD.44780 e 
HD.44100 devono essere gestiti con un comples¬ 
so set di istruzioni che potremo ottenere solo u- 
tilizzando un microprocessore esterno apposita¬ 
mente programmato. 

- Di questo set di istruzioni una parte viene utiliz¬ 
zata per inizializzare il microprocessore esterno, 
cioè l’ST6. 

Le rimanenti istruzioni sono necessarie al Display 
per prepararsi a ricevere tutti i nostri dati, cioè per 
configurarsi correttamente per ricevere i dati in 8 
bit oppure in 4+4 bit. 

Se non utilizzeremo questo set di istruzioni non 
riusciremo mai a visualizzare sul Display alcun ca¬ 
rattere. 















Fig.3 In un display 16 x 2 sono presenti 2 colonne di 16 caselle. In ogni casella vi sono 
40 “punti” per accendere i quali occorrerebbe un microprocessore da 1.280 bit. 


Per comunicare con il Display con 8 bit si utilizza¬ 
no tutti i piedini siglati da DBO a DB7, mentre per 
comunicare con 4+4 bit si utilizzano i soli piedini 
siglati da DB4 a DB7 (gli altri piedini da DBO a DB3 
non vengono utilizzati). 

Usando 4+4 bit, verranno inviati al Display i primi 
4 bit, poi i successivi 4 bit. 

Nota = Nei nostri programmi abbiamo utilizzato il 
sistema dei 4+4 bit. 

- Come abbiamo detto, quando invieremo un co¬ 
dice all’HD.44780 per far apparire un carattere, 
per poterlo visualizzare questo attenderà tutta una 
serie di istruzioni, ad esempio in quale delle 32 
caselle presenti nel Display vogliamo far apparire 
il segno grafico, se desideriamo utilizzare en¬ 
trambe le righe del Display oppure 1 sola, ecc. 
Queste istruzioni verranno accettate solo quando 
sul piedino 4 del display, denominato R/S, sarà 
presente un livello logico 0. 

- Dopo aver inserito tutte le istruzioni richieste, do¬ 
vremo mettere a livello logico 1 il piedino 4 del di¬ 
splay e solo a questo punto potremo inviare i da¬ 
ti, cioè la lettera - numero - simbolo che deside¬ 
riamo far apparire. 

- Ai due integrati HD.44780 - HD.44100 occorre un 
certo tempo per eseguire tutte queste operazioni 
e questo tempo di lavoro lo dovremo considerare 
e rispettare anche se si tratta di pochi millise¬ 
condi, diversamente nella casella interessata po¬ 
trebbero apparire dei caratteri strani e non signi¬ 
ficativi. 

Nei programmi dei vari esempi che troverete nel 
dischetto DF1208 troverete tutte queste istruzioni 
di ritardo, che dovrete necessariamente rispettare 
quando vi accingerete a scrivere dei vostri perso¬ 
nali programmi. 

Se non le rispetterete, non riuscirete mai a far fun¬ 
zionare un qualsiasi Display alfanumerico. 


Questi Display vengono chiamati intelligenti, solo 
perché dispongono di una memoria con un archi¬ 
vio di caratteri, ma per poter funzionare necessi¬ 
tano sempre di un microprocessore esterno (nel 
nostro caso un ST62/E25 con 28 piedini) che in¬ 
dichi loro quali caratteri desideriamo far apparire 
nelle 32 caselle. 


TABELLA dei CARATTERI PREDEFINITI 

Nella Tabella N.1 abbiamo riprodotto tutti i carat¬ 
teri presenti aH’interno della CGROM. 

Come potrete notare, sul lato destro sono presenti 
4 bit indicati con x x x x seguiti da altri 4 bit pre¬ 
definiti con 0 e 1, ad esempio: 

x x x x 0 0 0 1 

In alto sono riportati altri 4 bit predefiniti con 0 e 1, 
ad esempio: 

0 0 11 

Questa Tabella si usa come una Tavola Pitago¬ 
rica, quindi se volessimo far apparire sul display 
la lettera A, dovremmo sostituire le x presenti sul 
lato destro con i bit riportati nella casella in al¬ 
to. 

In questo esempio dovremo scrivere: 

0100-0001 

Nota = Abbiamo messo un segno - tra i primi quat¬ 
tro bit e i secondi quattro, solo per rendere l’e¬ 
sempio più chiaro, ma questo segno non dovrete 
mai inserirlo. 

Se volessimo far apparire una a (minuscola) do¬ 
vremmo scrivere: 

0110-0001 




































































































più precisamente DB4-DB5-DB6-DB7, collegati ai 
piedini C4-C5-C6-C7 del Connettore d’ingresso. 



Fig.5 Gli altri bit che non vengono utilizzati, cioè DBO- 
DB1-DB2-DB3 che fanno capo ai piedini 7-8-9-10, an¬ 
dranno collegati a massa. 


ELENCO COMPONENTI LX.1208 

RI = 10.000 ohm 1/4 watt 
R2 = 10.000 ohm 1/4 watt 
R3 = 10.000 ohm trimmer 
R4 = 10.000 ohm 1/4 watt 
R5 = 1 megaohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 100.000 pF poliestere 
C4 = 100.000 pF poliestere 
C5 = 10 mF elettr. 63 volt 
C6 = 1 mF poliestere 
DS1 = diodo tipo 1N.4150 
DS2 = diodo tipo 1N.4150 
IC1 = LM.358 

DISPLAY = LCD tipo LM.093X 
CONN.1/2 = connettore 24 poli 
PI = pulsante 
P2 = pulsante 


















































































































































Se volessimo far apparire il segno grafico > do¬ 
vremmo scrivere: 

0011-1110 

Anziché utilizzare questo codice binario per scri¬ 
vere una lettera o un carattere, potremo usare an¬ 
che un codice decimale e per questo motivo ab¬ 
biamo inserito sotto ad ogni casella il rispettivo nu¬ 
mero decimale. 

Quindi scrivendo 65 sul Display apparirà la lettera 
A maiuscola e scrivendo 97 apparirà la lettera a 

minuscola. 

Esempio in codice Binario 

Per scrivere la lettera A in codice binario dovremo 
scrivere questa istruzione: 

Idi car,01000001 b 

Esempio in codice Decimale 

Per scrivere la lettera A in codice decimale do¬ 
vremo scrivere questa istruzione: 

Idi car,65 

Esempio in codice ASCII 

Anziché utilizzare un codice binario o decimale, 
potremo scrivere direttamente in ASCII ed in que¬ 
sto caso l’istruzione sarà la seguente: 

car .ascii “A” 

Tra i programmi dimostrativi riportati nel dischetto 
DF1208 ne abbiamo inseriti diversi utilizzando que¬ 
sti tre diversi codici, quindi leggeteli attentamente 
perché con le istruzioni riportate comprenderete 
con estrema facilità quello che risulterebbe assai 
più complesso spiegare a parole. 


OPERAZIONI MATEMATICHE 

Molti si trovano in difficoltà con le operazioni ma¬ 
tematiche, perché non pensano che il numero che 
desiderano far apparire è un carattere grafico che 
verrà prelevato aH’interno della CGROM. 

Nel caso della somma 3+2 che ci dà come risulta¬ 
to 5, consultando la Tabella N. 1 vedremo che sot¬ 
to al numero 5 è indicato il numero 53. 

Per far apparire sul display il segno grafico “5”, a 
questo numero dovremo sommare la costante 48 
e così facendo otterremo 5+48 = 53 e se andiamo 


a vedere nella Tabella N. 1 noteremo che il nu¬ 
mero decimale 53 corrisponde effettivamente al 
carattere grafico “5”. 

Pertanto, l’istruzione che dovremo scrivere per 
svolgere questa operazione sarà: 

Idi a,3 
addi a,2 
addi a,48 
Id ddata,a 
cali dsend 

Se svolgiamo questa seconda operazione 9+7 = 
16 otterremo un risultato di due cifre, quindi per far 
apparire questi due segni grafici dovremo somma¬ 
re a 1 la costante 48 e, in tal modo, otterremo 49; 
consultando la Tabella N. 1 noteremo che il nu¬ 
mero 49 corrisponde al segno grafico “1”. 
Sommando al numero 6 la costante 48 otterremo 6 
+ 48 = 54 e sempre guardando la Tabella N. 1 sco¬ 
priremo che 54 corrisponde al segno grafico “6”. 
Pertanto l’istruzione che dovremo scrivere per 
questa operazione sarà: 

Idi a,1 
addi a,48 
Id ddata,a 
cali dsend 

Idi a,6 
addi a,48 
Id ddata,a 
cali dsend 


ISTRUZIONI di INIZIALIZZAZIONE 

Come abbiamo già detto, quando scriverete dei 
nuovi programmi dovrete sempre iniziare con tut¬ 
ta una serie di istruzioni di inizializzazione. 

Nei due programmi che troverete nel dischetto 
DF1208 questo set di istruzioni sono riportate: 

nel programma DISP093 nelle righe 77-109 
nel programma TESTER nelle righe 81-113 

In questi due programmi questo set di istruzioni è 
posizionato nelle righe 77-109 e nelle righe 81-113 
solo perché prima di queste abbiamo dovuto ripor¬ 
tare due diverse serie di variabili necessarie per 
far funzionare i due programmi. 

Come noterete questi due set di istruzioni, anche se 
posti in righe diverse, sono perfettamente identici. 
Dovrete sempre riportare nei vostri programmi per¬ 
sonalizzati tutte queste righe senza apportare al¬ 
cuna modifica, dopo tutte le vostre variabili. 


TABELLA n. 1 
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PER PASSARE dalla 1 ° alla 2° RIGA 

Poiché normalmente si scrive partendo dalla 1 0 ri¬ 
ga per poi passare alla 2° riga, le prime istruzioni 
che dovrete scrivere saranno: 

res 1,port_b “prepararsi per l’istruzione” 

Idi ddata,0000001 Ob “istruzione per la 1 0 riga” 
cali dsend “subroutine per invio dati” 

Continuerete quindi con le istruzioni che servono 
ad incrementare di una casella, cioè a far sì che 
la prima lettera o numero che vorrete far apparire 
si posizioni automaticamente nella prima casella, 
la seconda lettera nella seconda casella, ecc. 
Ammesso di voler scrivere A, dovrete scrivere il 
suo numero decimale, quindi: 

Idi ddata,00000110b “incrementa di una casella” 
cali dsend “subroutine per invio dati” 
set 1,port_b “fine set istruzioni” 

Idi ddata, 65 “trasferisci A in ddata” 
cali dsend “subroutine per invio dati” 

Per scrivere 16 caratteri in ogni riga si potrebbe 
scrivere 16 volte questa istruzione, mettendo nella 
riga Idi ddata il numero decimale che si desidera 
far apparire, ma poiché questa soluzione risulta po¬ 
co pratica, vi consigliamo di andare a vedere nel 
programma DISP093 come abbiamo risolto in mo¬ 
do più elegante il problema per far apparire sul Di¬ 
splay la parola N.ELETTRONICA. 

Per scrivere nella 2° riga posta sotto la 1 °, dovre¬ 
te scrivere queste istruzioni: 

res 1,port_b “prepararsi per l’istruzione” 

Idi ddata,IlOOOOOOb “posizionamento in 2° riga” 
cali dsend “subroutine per invio dati” 
set 1,port_b “fine set istruzioni” 

Ammesso di voler far apparire nella seconda ca¬ 
sella la lettera B, dovrete scrivere: 

Idi ddata,66 “trasferisci B in ddata” 
cali dsend “subroutine per invio dati” 

Vorremmo aggiungere che anche se sul display so¬ 
no visibili solo 16 caselle per riga, in pratica ve 
ne sono per ogni riga altre 24 nascoste e queste 
righe nascoste possono servire nel caso si desi¬ 
derino far scorrere sul display delle scritture da 
destra verso sinistra o viceversa. 

Nel programma DISP093 che troverete nel di¬ 
schetto DF1208, oltre a tutte le sorgenti abbiamo 
riportato anche degli esempi per ottenere questa 
funzione. 


NOTA per l’EDIT dell’ST6 

Dobbiamo precisare che l’EDIT, che vi avevamo 
fornito nei precedenti dischetti LX.1207 con l’in¬ 
tento di semplificare tutte le operazioni, risulta in¬ 
sufficiente per programmi molto lunghi come 
quelli utilizzati per questo Display alfanumerico si¬ 
glato LX.1208. 

Infatti questo EDIT accetta solo programmi che non 
superino i 30 Kilobyte quindi, quando li andrete a 
salvare, tutto quello che eccede i 30 K verrà ine¬ 
sorabilmente cancellato. 

Se perciò vorrete modificare e trasferire nella me¬ 
moria dell’ST6 un programma per questo Display 
alfanumerico o altri che superino i 30 K, dovrete 
necessariamente utilizzare l’Editor del DOS pre¬ 
sente nel vostro computer. 

Per caricare i due programmi presenti nel dischet¬ 
to DF1208 dovrete procedere come segue: 

Quando sul monitor appare C:\> dovrete inserire il 
dischetto nel drive A e scrivere: 

C:\>A: poi premete Enter 
A:\> installa poi premete Enter 

Il programma vi chiederà su quale directory vole¬ 
te installare il contenuto del dischetto e, poiché noi 
l’abbiamo già definita LX1208, dovrete solo pre¬ 
mere il tasto Enter. 

Si creerà così automaticamente la directory 
LX1208 e mentre verranno trasferiti nell’Hard-Disk 
tutti i programmi presenti nel dischetto floppy ver¬ 
ranno anche scompattati. 

Se usando questo metodo vi apparirà la scritta er- 
ror, vi consigliamo di ricaricare il dischetto 
nell’Hard-Disk utilizzando questo secondo metodo: 

C:\>MD LX1208 poi premete Enter 
C:\>COPY A:*.* C:\LX1208 poi premete Enter 
C:\>CD LX1208 poi premete Enter 
C:\LX1 208>installa poi premete Enter 

Nota = Per agevolarvi a rispettare le spaziature, 
abbiamo utilizzato una barra in colore che corri¬ 
sponde ad uno spazio. 

Ammesso che desideriate modificare il programma 
TESTER presente nel disco DF.1208, quando sul 
monitor appare C:\> scrivete: 

C:\>CD LX1208 (chiama la directory) 

C:\LX1 028>Edit TESTER.ASM (chiama Editor del 
Dos) 


Fig.6 La scheda di questo di¬ 
play andrà inserita nel Bus si¬ 
glato LX.1202, non dimenti¬ 
cando di innestare nello zoc¬ 
colo textool un micro ST6 tipo 
ST6/E25 per trasferire il pro¬ 
gramma DISP093.HEX oppure 
il TESTER.HEX. 



IMPORTANTE 

Con questo programma LX.1208 non viene più u- 
tilizzato l’Editor dell’ST6 ma l’Editor del DOS, 
quindi per trasferire i programmi dall’Hard-Disk al¬ 
la memoria dell’ST62/E25 non dovrete più con¬ 
vertire i programmi da .ASM in .HEX come vi ave¬ 
vamo insegnato in precedenza per tutti i program¬ 
mi presenti nel dischetto LX.1207, ma dovrete pro¬ 
cedere in modo completamente diverso. 

Dopo aver eseguito tutte le modifiche sui pro¬ 
grammi dovrete premere i tasti ALT F, poi portare 
il cursore sulla riga SALVA e premere Enter ed in¬ 
fine sulla riga ESCI e premere Enter. 

Ammesso di voler compilare il programma Dl- 


SP093, quando sul monitor apparirà C:\LX1 208> 
dovrete scrivere: 

C:\LX1 208>A DISP093.ASM 

Nota = Dopo la lettera A non mettete perché 
questa A è un programma Batch. 

Con questa istruzione convertirete automatica- 
mente il programma da .ASM a .HEX. 

Per trasferire i programmi già compilati in .HEX nel 
microprocessore posto sull’interfaccia LX.1202, 
dovrete richiamare la directory LX1208 e poi scri¬ 
vere semplicemente: 

C:\LX1 208>ST6PGM poi premere Enter 











































A questo punto sul monitor apparirà una masche¬ 
ra che vi chiederà quale programma intendete tra¬ 
sferire e quale micro avete scelto e, una volta che 
avrete risposto a queste domande, potrete memo¬ 
rizzare il vostro micro ST62/E25. 

Tutte le istruzioni relative a come trasferire un pro¬ 
gramma dall’Hard-Disk ad un micro ST6 le abbia¬ 
mo riportate negli articoli pubblicati sulle riviste 
N.172/173-174-175/176-179-180-181, quindi a chi 
fosse interessato a questo argomento suggeriamo 
di procurarsi tali numeri al più presto prima che ven¬ 
gano esauriti. 


SCHEMA ELETTRICO 

Lo schema elettrico di questo progetto, come po¬ 
tete vedere in fig.4, è quanto di più semplice si pos¬ 
sa immaginare. 

Abbiamo contrassegnato otto dei 15 piedini del di¬ 
splay con le sigle da DBO a DB7 per non confon¬ 
derli con i segnali da B0 a B7 presenti nel connet¬ 
tore che va inserito nella scheda bus LX.1202. 
Nell’articolo abbiamo spiegato che per gestire que¬ 
sto display bisogna usare un codice di 8 bit, che 
andrà applicato sui piedini DBO - DB1 - DB2 - DB3 
- DB4 - DB5 - DB6 - DB7 (piedini dal numero 7 al 
numero 14), mentre osservando lo schema elettri¬ 
co riportato in fig.4 si potrà notare che i piedini da 
DBO a DB3 sono collegati a massa e che il se¬ 
gnale entra nei soli piedini da DB4 a DB7. 

Questa configurazione è stata adottata perché per 
gestire questo display abbiamo usato un codice 
4+4 bit. 

Oltre al display, nello schema elettrico è presente 
anche un amplificatore operazionale siglato IC1/A; 
a questo proposito vi chiederete se tale amplifica¬ 
tore sia indispensabile per far funzionare questo di¬ 
splay e noi vi rispondiamo che non serve. 

Infatti l’abbiamo inserito soltanto per potervi dimo¬ 
strare come sia possibile, con il programma Te¬ 
ster, trasformare questo display in un voltmetro. 
Dobbiamo subito precisare che nell’ingresso di 
questo operazionale non è possibile inserire del¬ 
le tensioni superiori ai 5 volt; per poterlo fare sarà 
necessario applicare sull’ingresso dei partitori re¬ 
sistivi da 1/10 -1/100. 

Oltre a questo particolare, dobbiamo anche ricor¬ 
darvi di rispettare la polarità della tensione sull’in¬ 
gresso, perché se invertirete il positivo con il ne¬ 
gativo sul display appariranno 0 volt. 

Il trimmer R3 collegato al piedino 3 serve per va¬ 
riare la luminosità delle lettere o dei numeri che 
appariranno nelle diverse caselle. 

Tutti i piedini del display e quello d’uscita dell’o- 
perazionale vengono collegati al Connettore 1/2 
che andrà innestato nella scheda bus LX.1202. 


REALIZZAZIONE PRATICA 

Sul circuito stampato siglato LX.1208 dovrete mon¬ 
tare tutti i componenti visibili in fig.7. 

Vi consigliamo di iniziare dal connettore maschio 
a 24 terminali e di procedere inserendo gli altri due 
connettori maschi a 4 terminali (nello schema 
pratico si vede solo quello di destra) ed il connet¬ 
tore femmina a 15 terminali che userete come 
zoccolo per il display. 

Completata questa operazione, potrete inserire lo 
zoccolo per l’integrato IC1 e tutti gli altri compo¬ 
nenti richiesti, cioè pulsanti, trimmer, condensatori 
e resistenze. 

Nel montaggio dovrete solo rispettare la polarità 
dei due diodi al silicio DS1-DS2, posizionando il 
lato del loro corpo contornato da una fascia nera 
come appare ben visibile nello schema pratico di 
fig.7. 

Completato il montaggio, dovrete inserire nello zoc¬ 
colo l’integrato IC1, rivolgendo la tacca di riferi¬ 
mento a forma di U presente sul suo corpo verso 
il condensatore C4. 

Per fissare il display dovrete inserire nei quattro 
fori presenti sullo stampato i distanziatori plastici 
inclusi nel kit, dopodiché potrete innestare i termi¬ 
nali del display nello zoccolo femmina, facendo en¬ 
trare i perni dei distanziatori nei fori presenti sullo 
stampato del display. 


PROGRAMMI PER LM093 

Nel dischetto DF1208 sono riportati due program¬ 
mi per utilizzare il display alfanumerico in tutti i 
modi possibili. 

Questi due programmi sono denominati: 

DISP093.ASM 

TESTER.ASM 

A questi due programmi occorrono altri due files 
chiamati: 

TB_CGR01.ASM 

TBCGR02.ASM 

Questi due ultimi files TB_CGR sono in pratica del¬ 
le tabelle che vi serviranno per utilizzare una di¬ 
rettiva denominata .input. 

Questa direttiva altro non è che una istruzione in¬ 
serita nel file sorgente, che in fase di compilazio¬ 
ne “richiama” una serie di dati contenuti in un file 
diverso dal sorgente. 

Quando assemblerete il programma DISP093.A- 


DISPLAY 


è 


è 


V. INPUT 

+ - 
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CONN. 1/2 


Fig.7 Schema pratico di montaggio della scheda LX.1208. Sul 
circuito stampato dei display dovrete saldare il connettore ma¬ 
schio a 15 terminali, che dovrete poi innestare nel circuito stam¬ 
pato LX.1208. 
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Fig.8 Foto dello stampato LX.1208 con sopra già montati tutti i componenti richiesti. No¬ 
ta = Nel kit, anziché trovare un connettore maschio da 24 poli e due da 4 poli potreste tro¬ 
varne uno solo da 32 terminali, che dovrete tagliare per ottenere i tre pezzi richiesti. 






































































































SM, il compilatore andrà a ricercare il file: 

TB_CGR01 .ASM 

e lo ingloberà al suo interno, formando così un u- 

nico file che si chiamerà: DISP093.HEX. 

Quando assemblerete il programma TESTER.A- 
SM, il compilatore andrà a ricercare il file TB_C- 
GR02.ASM e lo ingloberà al suo interno, forman¬ 
do così un unico file che si chiamerà: 

TESTER.HEX. 

Quindi quando assemblerete questi due pro¬ 
grammi non dovrete assolutamente preoccuparvi 
di questi files TB_CGR, perché le operazioni di ri¬ 
cerca e di inserimento vengono eseguite automa¬ 
ticamente. 

La direttiva chiamata .input è simile ad una su¬ 
broutine, con la sola differenza che viene eseguita 
in fase di compilazione e non durante l’esecuzione 
del programma stesso. 

Per terminare aggiungiamo che una volta inserita 
la LX.1208 di questo display alfanumerico nel bus 
LX.1202, in quest’ultimo bus non potrete inserire 
altre schede, tipo TRIAC o RELE’. 


Programma DISP093.HEX 

Questo programma, che utilizza i soli pulsanti PI 
- P2 presenti nella scheda LX.1208, vi permet¬ 
terà di visualizzare il vostro nome e cognome o 
qualsiasi altra scritta sul display, a condizione 
di utilizzare un massimo di 16 caratteri per ri¬ 
ga. 

Facciamo presente che è necessario considerare 
gli spazi come caratteri. 

Il vostro nome e cognome o una qualsiasi al¬ 
tra scritta, dovrà essere scritto all’interno del 
programma .ASM nelle righe che vi indichere¬ 
mo. 

Dopo aver scritto le parole che dovranno apparire 
sul display, dovrete riassemblare il programma ed 
infine caricarlo nel micro ST62/E25, che andrà in¬ 
serito nello zoccolo textool presente nella scheda 

bus LX.1202. 

Se caricherete nel micro ST62/E25 il programma 
DISP093.ASM, ovviamente dopo averlo assem¬ 
blato in DISP093.HEX, sul display vedrete appari¬ 
re in ordine alcune scritte: 

N.ELETTRONICA 
** DISP093 ** 


Queste scritte rimarranno visualizzate per circa 3 
secondi, dopodiché apparirà: 

[PI] > 

PER PROCEDERE 

Se non premerete il pulsante PI vedrete alternar¬ 
si le due scritte sopra riportate con una cadenza di 
circa 1 secondo. 

Se invece premerete il pulsante PI per più di 3 se¬ 
condi circa, apparirà questa nuova scritta: 

-NOME-NOME-NOME- 

-COGNOME-COGNOME 

Come noterete, ogni riga occupa un totale di 16 ca¬ 
ratteri. 

Questa scritta rimarrà visualizzata sul display per 
circa 6 secondi, dopodiché apparirà la scritta: 

LE FUNZIONI 
PREVISTE SONO: 

Anche questa scritta rimarrà visualizzata per circa 
6 secondi, dopodiché apparirà questa scritta: 

1- MAIUSC.> minus 

2- ROTAZIONE 

Questa rimarrà visualizzata per circa 6 secondi, 
dopodiché apparirà: 

3- SCOMPOSIZIONE 

4- VISUAL.CG RAM 

e nuovamente vedrete apparire: 

[PI] > 

PER PROCEDERE 

Come noterete, sulla base delle scritte apparse, po¬ 
trete ottenere 4 diverse funzioni che sono nume¬ 
rate 1-2-3-4. 

Solo dopo che saranno apparse tutte le scritte che 
vi abbiamo sopra indicato, potrete utilizzare il ta¬ 
sto PI per selezionare una della 4 funzioni. 

Se non premerete il pulsante PI vedrete nuova¬ 
mente ripetersi all’infinito le stesse scritte. 

Quando apparirà PI > PER PROCEDERE dovre¬ 
te tenere premuto questo tasto per almeno 3 se¬ 
condi e apparirà la scritta: 

SCELTA FUNZIONE 
.[?] [P2] > 



A questo punto, utilizzando il tasto P2 potrete sce¬ 
gliere una della quattro funzioni numerate 1-2-3- 
4. 

Questa scritta rimarrà sui display fino a quando non 
premerete il pulsante P2. 

Se terrete premuto per almeno 3 secondi il pul¬ 
sante P2, apparirà questa scritta: 

SCELTA FUNZIONE 
.[1] [P2] > 

Come potete vedere, nelle due parentesi quadre è 
sparito il ? ed è apparso il numero 1. 

Premendo per una seconda volta P2 apparirà il 
numero 2, premendo una terza volta P2 apparirà 
il numero 3 e premendolo per la quarta volta ap¬ 
parirà il numero 4. 

Fate attenzione a premerlo per la quinta volta, per¬ 
ché se sul display apparirà il numero 5 uscirete dal 

menu. 

Ammesso di voler visualizzare la funzione 1-MAIU- 
SC.> minus quando appare: 

SCELTA FUNZIONE 
.[1] [P2] > 

dovrete premere per circa 3 secondi il pulsante PI 
e comparirà la scritta: 

-NOME-NOME-NOME- 

-COGNOME-COGNOME 

dopo circa 5 secondi vi apparirà la stessa scritta 
ma in minuscolo, ovvero: 

-nome-nome-nome- 

-cognome-cognome 

Tale scritta in minuscolo resterà visualizzata per 
circa 5 secondi, dopodiché vi riapparirà nuova¬ 
mente la scritta: 

SCELTA FUNZIONE 
.[?] [P2] > 

A questo punto, se premerete il tasto P2 per due 
volte consecutive, sceglierete la funzione 2-RO- 
TAZIONE, quindi quando apparirà: 

SCELTA FUNZIONE 
.[2] [P2] > 

tenendo premuto per 3 secondi il tasto PI, vedre¬ 
te apparire un divertente effetto perché il vostro no¬ 
me partirà dalla seconda riga, scorrendo da sini¬ 


stra verso destra, per poi riportarsi sulla prima riga 
scorrendo da destra verso sinistra per 4 volte con¬ 
secutive, dopodiché riapparirà la scritta: 

SCELTA FUNZIONE 
.[?] [P2] > 

Se ora premerete il tasto P2 per tre volte conse¬ 
cutive, sceglierete la funzione 3-SCOMPOSIZIO- 
NE, quindi quando apparirà: 

SCELTA FUNZIONE 
.[3] [P2] > 

dovrete tenere premuto il pulsante PI per circa 3 
secondi e rilasciandolo vedrete che i caratteri ri¬ 
portati nella sola prima riga cominceranno a scom¬ 
porsi, cioè vedrete i caratteri della prima riga al¬ 
lontanarsi ad uno ad uno scorrendo verso destra, 
fino a scomparire totalmente, poi li vedrete ritorna¬ 
re da destra verso sinistra fino a ricostruire l’inte¬ 
ra parola. 

Una volta ricostruiti i 16 caratteri sulla prima riga, 
nuovamente vedrete apparire la scritta: 

SCELTA FUNZIONE 
.[?] [P2] > 

Se ora premerete il tasto P2 per quattro volte con¬ 
secutive, sceglierete la funzione 4-VISUAL.CG 
RAM quindi quando apparirà: 

SCELTA FUNZIONE 
.[4] [P2] > 

dovrete sempre tenere premuto il tasto PI per al¬ 
meno 3 secondi e sulla prima riga del display ve¬ 
drete apparire 8 simboli grafici generati apposi¬ 
tamente a scopo didattico, più un cursore non lam¬ 
peggiante. 

I programmi inseriti nel dischetto DF.1208 servono 
principalmente per farvi vedere come si debbano 
scrivere le varie istruzioni per far funzionare que¬ 
sto display alfanumerico. 

Solo dopo che avrete preso una certa confi¬ 
denza con questi programmi, potrete modificar¬ 
li, o prelevare direttamente dalle nostre sor¬ 
genti tutte le righe che potrebbero interessar¬ 
vi. 

Una modifica molto semplice che potrete appor¬ 
tare è quella di far apparire sui display il vostro no¬ 
me e cognome o qualsiasi altra scritta. 

Se sulla prima riga volete far apparire il vostro no¬ 
me che potrebbe essere ALESSANDRO - MAR¬ 
CO - VINCENZO, ecc. dovrete andare alla riga 










N.684 posta all’interno del programma sorgente Dl- 
SP093.ASM e sostituire la scritta da noi inserita 
con il vostro nome. 

Se in corrispondenza della seconda riga volete far 
apparire il vostro cognome che potrebbe essere 

BIANCHI - ALBERTAZZI - FANTOZZI, ecc., do¬ 
vrete andare alla riga N.685 e sostituire la scritta 
da noi inserita con il vostro cognome. 

Nota importante = Qualsiasi cosa scriverete nel¬ 
le righe 684 e 685, dovrete sempre farlo in carat¬ 
teri maiuscoli e non superare mai i 16 caratteri 
per riga compresi gli spazi. 

Dopo aver eseguito queste modifiche dovrete pre¬ 
mere i tasti ALT F, poi portare il cursore sulla riga 
SALVA e premere Enter ed infine sulla riga ESCI 
e premere Enter. 

Dopodiché dovrete richiamare il programma 
LX1208 scrivendo: 

C:\>CD LX1208 poi premere Enter 

e scrivere: 

C:\LX1 208>A DISP093.ASM 

Nota = Dopo la lettera A non mettete perché 
questa A non è altri che un programma Batch che 
lancia il compilatore in assembler. 

Con questa istruzione convertirete automatica- 
mente il nostro programma da .ASM in .HEX. 

Per trasferire questo programma già compilato in 
.HEX nel microprocessore posto sull’interfaccia 
LX.1202, dovrete richiamare la directory LX1208 
e poi scrivere semplicemente: 

C:\LX1 208>ST6PGM poi premere Enter 

A questo punto sul monitor apparirà una masche¬ 
ra che vi chiederà quale programma desiderate tra¬ 
sferire e su quale micro ST6; fornite al computer 
le esatte risposte, il vostro programma modificato 
verrà memorizzato nel micro ST62/E25. 


TESTER.HEX 

Con questo programma dimostrativo desideria¬ 
mo insegnarvi ad utilizzare l’A/D converter pre¬ 
sente aN’interno del microprocessore ST6/E25 e 
per farlo abbiamo realizzato con questo display 

alfanumerico un semplice voltmetro elettroni¬ 
co utilizzando entrambe le righe presenti nel di¬ 
splay. 


Sulla prima riga faremo apparire il valore della 
tensione in numero, mentre sulla seconda riga 
faremo apparire una barra che si allungherà di 
1 riga ogni 0,1 volt e di 1 quadretto ogni 0,5 
volt. 

Chi fosse interessato a comprendere come siamo 
riusciti ad ottenere queste due condizioni, dovrà 
leggere attentamente il programma TESTER.ASM 
e i commenti riportati su ogni riga. 

Vogliamo subito far presente che il massimo va¬ 
lore di tensione che potremo leggere con questo 
voltmetro è di soli 5 volt, quindi non applicate 
sull’ingresso dell’operazionale IC1/A tensioni mag¬ 
giori. 

Per leggere tensioni di 50 volt fondo scala, do¬ 
vrete necessariamente utilizzare dei partitori resi¬ 
stivi come illustrato nelle figg.10-11. 

La tensione da misurare, applicata sull’ingresso 
dell’operazionale IC1/A, verrà prelevata dal suo 
piedino d’uscita 7 ed inviata all’A/D converter pre¬ 
sente all’interno del microprocessore ST6/E25, che 
la convertirà in un numero decimale compreso tra 
0 e 255. 

L’A/D converter per un valore di tensione di 5 volt 
ci dà un numero decimale di 255; se dividiamo 255 
per 5 otteniamo 51, quindi è intuitivo che per un va¬ 
lore di tensione di 1 volt l’A/D converter ci darà 
un numero decimale di 51 e per un valore di 2 volt 
ci darà un numero decimale di 102 e per 3 volt un 
numero decimale di 153. 

Se misurassimo una tensione di 2,5 volt, in teoria 
l’A/D converter dovrebbe darci il numero 51 x 2,5 
= 127,5, ma poiché in pratica non ci darà mai un 
numero con la virgola, sulla sua uscita otterremo 
dei numeri variabili molto prossimi a 127, ad e- 
sempio 127-128-128-129-127-129, perché l’A/D 
converter dell’ST6 non è molto stabile. 

Sommando i 6 numeri del nostro esempio otterre¬ 
mo un totale di 768, che diviso per 6 ci darà il va¬ 
lore medio: 

768 : 6 = 128 

Dividendo 128 per 51 otterremo: 

128 : 51 = 2,50 

Per ottenere una maggiore precisione nel nostro 
programma leggeremo i numeri decimali che l’A/D 
converter ci fornirà per ben 32 volte, poi una vol¬ 
ta sommati li divideremo per 32. 

Per far apparire il numero 2,5 metteremo il nu¬ 
mero 2 in un byte e il numero 5 in un altro by¬ 
te. 




4,5 V. 


Fig.9 II programma TESTER.HEX per¬ 
mette di utilizzare questo display alfa- 
numerico in un Voltmetro in grado di mi¬ 
surare un massimo di 5 volt. Per prova¬ 
re questo Voltmetro potrete procurarvi 
un trimmer da 10.000 ohm ed una pila 
da 4,5 volt. 

Ruotando il suo cursore vedrete appari¬ 
re sui display il valore della tensione. 


Fig.10 Volendo utilizzare la funzione 
Voltmetro per leggere tensioni maggio¬ 
ri, dovrete applicare sull’ingresso un 
partitore resistivo composto da tre sole 
resistenze. 

Con questo partitore potrete leggere fi¬ 
no ad un valore massimo di 50 volt. 



15.000 ohm 



Fig.11 Utilizzando il partitore resistivo di 
fig.10 la lettura potrebbe non risultare 
precisa a causa delle “tolleranze” delle 
resistenze. Per risolvere questo proble¬ 
ma, potrete utilizzare una sola resisten¬ 
za ed un trimmer che andrà tarato in mo¬ 
do da leggere l’esatta tensione applica¬ 
ta sull’ingresso. 










































































































Come vi abbiamo già spiegato in precedenza, per¬ 
ché il display intelligente faccia apparire un qual¬ 
siasi segno grafico contenuto all’interno della sua 
CGROM, gli deve giungere un numero ben diver¬ 
so dal 2 e dal 5 inseriti in questi due byte, per cui 
dovremo sommare questi due numeri alla co¬ 
stante 48. 

Otterremo così: 

2 + 48 = 50 
5 + 48 = 53 

Consultando la Tabella N.1 vedremo che il nume¬ 
ro 50 corrisponde al simbolo grafico 2 ed il nu¬ 
mero 53 al simbolo grafico 5. 

Per visualizzare la barra che appare sulla secon¬ 
da riga utilizziamo i due numeri 2 e 5, che abbia¬ 
mo messo in precedenza nei due byte, e con que¬ 
sti due numeri andiamo nel file TB_CGR02.ASM 
per prelevare i simboli grafici che ci serviranno 
per accendere tutte le caselle interessate. 

Poiché con 5 volt si accendono 10 caselle oriz¬ 
zontali, è ovvio che disponendo di una tensione di 
2,5 volt si accenderanno solo 5 caselle. 

Per provare questo voltmetro potrete procurarvi un 
trimmer da 10.000 ohm, più una pila da 4,5 volt, 
collegandoli come visibile in fig.9. 

Ruotando il cursore del trimmer da un estremo 
all’altro, vedrete variare sulla prima riga del display 
il numero da 0 volt fino ad un massimo di 4,5 volt 
e sulla seconda riga la barra aumentare progres¬ 
sivamente fino a raggiungere un massimo di 9 qua¬ 
dretti. 

Volendo utilizzare questo tester per misurare ten¬ 
sioni superiori a 5 volt, dovrete applicare sull’in¬ 
gresso un partitore resistivo con i valori riportati in 
fig.10 e, in tal modo, otterrete un fondo scala di 
50 volt. 

Non è possibile utilizzare dei partitori resistivi che 
diano dei valori di fondo scala di 10-100-200 volt, 
perché il programma è impostato per leggere un 

massimo di 5 volt. 

Come noterete, tra le due cifre rimane sempre in¬ 
serita la virgola, quindi se avete utilizzato il parti¬ 
tore di fig.10 e sull’ingresso inserite 18 volt, sul di¬ 
splay apparirà il numero 1,8 volt. 

Poiché le resistenze hanno una loro tolleranza, il 
partitore di fig.10 potrebbe non fornirvi l’esatto va¬ 
lore di tensione; per risolvere questo problema la 
soluzione migliore sarebbe quella di utilizzare lo 
schema riprodotto in fig.11. 

Per tarare il trimmer potrete prendere una esatta 
tensione continua che non risulti maggiore di 50 
volt e partendo con il cursore tutto ruotato verso 


massa, lo ruoterete lentamente in senso inverso fi¬ 
no a leggere l’esatta tensione applicata sull’in¬ 
gresso. 

Ammesso di aver scelto una tensione di 28 volt, 
dovrete ruotare questo trimmer fino a leggere sui 
display il numero 2,8 volt. 


NOTA IMPORTANTE 

Non invertite la polarità della tensione sull’ingres¬ 
so dell’operazionale IC1/A, perché sui display ve¬ 
drete sempre apparire 0,0 volt. 

Non applicate sull’ingresso tensioni maggiori di 5 
volt (per pochi istanti l’integrato accetta anche 9 
volt), diversamente si potrebbe danneggiare il mi¬ 
croprocessore ST6/E25. 

Al programma TESTER.ASM, che funziona solo co¬ 
me voltmetro per leggere una tensione di 5 volt mas¬ 
simi, non è possibile apportare alcuna modifica. 
Questo programma, come già vi abbiamo accen¬ 
nato, è un dimostrativo che vi permetterà di vede¬ 
re tutte le varie soluzioni che abbiamo adottato per 
far apparire un numero proporzionale alla tensione 
e come si utilizzano le tabelle del TB_CGR02.A- 
SM e l’A/D converter. 

Come già saprete, per poter memorizzare il pro¬ 
gramma TESTER.ASM all’interno del micro ST6, 
lo dovrete prima convertire in .HEX e per farlo do¬ 
vrete digitare: 

C:\>CD LX1208 poi premete Enter 

C:\LX1 208>A TESTER.ASM poi premete Enter 

Per poter trasferire il programma convertito in .HEX 
sul micro ST6 dovrete semplicemente scrivere: 

C:\LX1 208>ST6PGM poi premere Enter 

e rispondere, come già sapete, a tutte le domande 
che appariranno sul monitor del computer. 

KIT ESAURITO 

vedi LX.1208/N nelle pagine seguenti 
COSTO DI REALIZZAZIONE 

Tutti i componenti necessari per la realizzazione di 
questo progetto per Display alfanumerico, che po¬ 
tete vedere riprodotti in fig.7 (Escluso il disco 


DF.1208).L.78.500 

Il programma DF.1208.L.12.000 

Costo dello stampato LX.1208.L.10.000 


Ai prezzi riportati, già comprensivi di IVA, andranno 
aggiunte le sole spese di spedizione a domicilio. 


126 





IL KIT LX.1208/N con il nuovo DISPLAY WH.1602A 


Poiché il display alfanumerico LM.093LN non vie¬ 
ne più fabbricato, ci siamo dati da fare per cerca¬ 
re un sostituto che lo rimpiazzasse nel kit LX.1208. 

Dopo un’accurata ricerca, abbiamo scelto il display 
WH.1602A della Hitachi, che è equivalente al di¬ 
splay LM.093N, eccetto che nella disposizione di 
alcuni piedini e nella definizione di alcuni caratteri 
alfanumerici (vedi tabella nelle pagine seguenti). 

Proprio perché la piedinatura del display 
WH.1602A non collima perfettamente con quella 
del display LM.093N (se confrontate la fig.5 con la 
fig.12 vi accorgerete subito che il display della Hi¬ 
tachi ha un piedino in più), abbiamo pensato noi a 
disegnare e a fare incidere un nuovo circuito stam¬ 
pato al quale abbiamo dato la sigla LX.1208/N. 

In questo modo non incontrerete alcuna difficoltà 
nel realizzare la scheda e soprattutto nel montare 
il nuovo display alfanumerico. 

Inoltre, come siamo soliti fare per tutti i nostri kit, 
abbiamo già montato e collaudato questa scheda, 
e quindi possiamo assicurarvi che il circuito fun¬ 
ziona esattamente come funzionava l’altro. 

Vale la pena sottolineare che il display WH.1602A 
utilizzato, è un display LCD alfanumerico compo¬ 
sto da due righe di 16 caratteri. 

Come vi abbiamo anticipato, rispetto al display 
LM.093LN, che aveva solo un piedino per regola¬ 
re la luminosità, il display WH.1602A ha due con¬ 
trolli: con i collegamenti al positivo di alimentazio¬ 
ne e a massa dei piedini 15-16 viene retro illumi¬ 


nato, mentre il trimmer R4 collegato al piedino 3 
consente di regolarne il contrasto. 

Per la descrizione dello schema elettrico e per il 
montaggio dei componenti sul circuito stampato, ri¬ 
mandiamo a quanto già descritto nelle pagine pre¬ 
cedenti, perché il funzionamento del circuito non è 
cambiato. 

Per quanto riguarda l’elenco componenti e i di¬ 
segni degli schemi elettrico e pratico, tenete in¬ 
vece presenti quelli riportati in queste pagine. 


IL SET dei CARATTERI ALFANUMERICI 

Nella pagina seguente abbiamo riportato anche la 
tabella relativa ai caratteri alfanumerici gestiti dal 
display WH.1602A, che, come vi dicevamo, non 
coincide perfettamente con il set di caratteri che ve¬ 
niva gestito dal vecchio display. Infatti se la con¬ 
frontate con la Tabella N.1 di questo articolo, ve¬ 
drete che alcuni caratteri sono diversi. 

In particolare, il display WH.1602A non ha tra i suoi 
caratteri le due frecce che nella Tabella N.1 si tro¬ 
vano alle posizioni 126 e 127. 

Per questo motivo alcune delle istruzioni presenti 
nei programmi DISP093.ASM e TESTER.ASM 

vanno modificate, come ora vi spieghiamo. 

Dopo la modifica, al posto delle frecce alle posi¬ 
zioni 126 e 127 della Tabella N.1, appariranno le 
frecce alle posizioni 62 e 60 della tabella del set di 
caratteri del display WH.1602A. 



Fig.12 Connessioni del display alfa- 
numerico WH.1602A. Il microproces¬ 
sore ST6 esterno dialoga con questo 
display a 4+4 bit attraverso i piedini 
da DB4 a DB7, che fanno capo ai pie¬ 
dini 11-12-13-14 (vedi fig.13). I piedini 
da DBO a DB3, che fanno capo ai pie¬ 
dini dal 7 al 10, vanno collegati a mas¬ 
sa perché non vengono utilizzati. 
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Fig.13 Schema elettrico del circuito siglato 
LX.1208/N con display alfanumerico. Colle¬ 
gando i piedini 16-15 rispettivamente a 
massa e al positivo di alimentazione, il di¬ 
splay si retro illumina. Per regolare il con¬ 
trasto, dovete agire sul trimmer R4. 
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ELENCO COMPONENTI LX.1208/N 



LM 358 


Fig.14 Connessioni viste da sopra deH’am- 
plificatore operazionale LM.358, siglato 
IC1/A nello schema elettrico di fig.13. Co¬ 
me già spiegato nell’articolo, questo ampli¬ 
ficatore non è indispensabile al funziona¬ 
mento del display, ma è stato inserito per 
dimostrarvi come sia possibile, con oppor¬ 
tune istruzioni di programma (vedi pro¬ 
gramma TESTER.ASM), trasformare il di¬ 
splay in un voltmetro. 


RI = 10.000 ohm 1/4 watt 
R2 = 10.000 ohm 1/4 watt 
R3 = 4,7 ohm 1/2 watt 
R4 = 10.000 ohm trimmer 
R5 = 10.000 ohm 1/4 watt 
R6 = 1 Megaohm 1/4 watt 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 100.000 pF poliestere 
C4 = 100.000 pF poliestere 
C5 = 10 microF. elettrolitico 
C6 = 1 microF. poliestere 
DS1 = diodo tipo 1N.4150 
DS2 = diodo tipo 1N.4150 
IC1 = integrato tipo LM.358 
DISPLAY = LCD tipo WH.1602A 
CONN.1/2 = connettore 24 poli 
PI = pulsante 
P2 = pulsante 
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DISPLAY = WH1602A 
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CONN. 1/2 

Fig.15 Schema pratico di montaggio della scheda LX.1208/N. Il montaggio di questo cir¬ 
cuito non presenta particolari difficoltà e se rispetterete la polarità del condensatore e- 
lettrolitico C5 e dei due diodi al silicio DS1-DS2, il circuito funzionerà senza problemi. Sul 
lato opposto a quello visibile, vanno saldati i connettori a 4 terminali che, insieme al con¬ 
nettore CONN.1/2, vi serviranno per innestare la scheda nel Bus siglato LX.1202. 


Nel programma DISP093.ASM alle righe 672 - 685 
- 692, dovete sostituire l’istruzione: 


.byte 

con l’istruzione: 

.byte 


OllllllOb 


oonmob 


Nel programma TESTER.ASM dovete invece an¬ 
dare dopo la riga 454 e nella tabella riportata, so¬ 
stituire l’istruzione: 


.byte 

con l’istruzione: 

.byte 


OllllllOb 


OOlllllOb 


Poi dovete lasciare invariata l’istruzione: 


e infine sostituire l’istruzione: 

.byte Olllllllb 

con l’istruzione: 

.byte OOllllOOb 

COSTO di REALIZZAZIONE 

Costo dei componenti necessari per la realizzazio¬ 
ne del kit con display alfanumerico WH.1602A, si¬ 
glato LX.1208/N, visibile in fig.15, escluso solo il 
dischetto DF.1208 
Euro 26,00 

Costo del solo circuito stampato LX.1208/N 
Euro 5,20 

Costo del dischetto DF.1208 con i programmi per 
display alfanumerico con micro ST6 

Euro 6,20 


.byte 


32,32,32 











































TABELLA PER DISPLAY LCD tipo WH 1602A 
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Quando si scrivono programmi per qualsiasi mi¬ 
croprocessore anche i più esperti possono com¬ 
mettere degli errori di sintassi oppure logici. 

I primi, cioè quelli di sintassi, vengono già rilevati 
in fase di compilazione, perciò è abbastanza faci¬ 
le scoprirli e correggerli; i secondi, cioè quelli logi¬ 
ci, possono essere scoperti solo se si dispone di 
un emulatore real-time. 

Se non si possiede un emulatore il solo sistema 
per verificare che il programma risulti corretto è 
quello di trasferirlo in un micro ST6 riprogramma¬ 
bile, cioè provvisto di una finestra. 

Se, dopo averlo collocato nel circuito che dovrà ge¬ 
stire, si verifica che non funziona, bisogna ricon¬ 
trollare il programma istruzione per istruzione, 
correggere gli errori commessi, sempre che si rie¬ 
sca a trovarli, ricompilare il programma con l’as- 
sembler, cancellare IST6, ed infine riprogram¬ 
marlo e “testarlo” nuovamente, perché non è det- 


cucina e quella della camera da letto e se non in¬ 
dichiamo nel programma quale porta deve essere 
aperta, si aprirà una porta qualsiasi e non quella 
d’ingresso come noi volevamo. 

Un emulatore ci offre parecchi vantaggi. 

Prima di tutto quello di non dover più acquistare un 
certo numero di ST6 riprogrammabili e, poiché il 
loro prezzo è salito alle stelle, si risparmierà una 
cifra considerevole. 

Inoltre potendo controllare prima il programma, non 
si perderà del tempo per programmarli, cancellarli 
e riprogrammarli. 

Infatti dopo aver eseguito un test completo sul vo¬ 
stro programma, se non rileverete delle anomalie 
potrete tranquillamente trasferirlo su un ST6 non 
riprogrammabile perché, avendolo già testato, 
avrete la matematica certezza che funzionerà. 


SOFTWARE emulatore per 


to che non vi siano altri errori che potrebbero es¬ 
sere sfuggiti ad un primo controllo. 

Non è inoltre da escludere che nonostante la buo¬ 
na volontà non si riesca a capire in quale istruzio¬ 
ne è presente l’errore e per scoprirlo ci potrebbe 
volere molto tempo e pazienza. 

Con un emulatore risulta molto più facile ed anche 
meno costoso programmare qualsiasi ST6, perché 
si può controllare passo per passo ogni istruzio¬ 
ne mentre viene eseguita. In questo modo è pos¬ 
sibile capire dove e perché si è generato l’errore. 

Ad esempio, potremmo aver scritto un programma 
che ad un tempo prefissato deve accendere una 
lampadina, e solo dopo aver programmato l’ST6 ci 
accorgiamo che questo tempo risulta dimezzato o 
raddoppiato perché non abbiamo tenuto conto 
della frequenza del quarzo oppure abbiamo fatto 
una somma anziché una moltiplicazione. 

Oppure potremmo aver scritto un programma per 
svolgere una semplice funzione, ad esempio: 

- se suona il campanello 

- vai ad aprire la porta 

ma se non abbiamo tenuto presente che in casa ci 
sono diverse porte, quella d’ingresso, quella della 


Per questi motivi i softwaristi e gli hobbisti sono al¬ 
la ricerca di un emulatore corredato di software 
che risulti facile da usare, molto economico e che 
permetta un’emulazione completa ed in tempo rea¬ 
le di un micro ST6. 

Per risolvere questo problema abbiamo acquistato 
tutti gli emulatori per ST6 e relativo software che 
siamo riusciti a reperire sul mercato, poi ad uno ad 
uno li abbiamo testati inserendo apposta nei no¬ 
stri programmi degli errori con diversi livelli di dif¬ 
ficoltà per verificare con quale grado di facilità ci 
consentivano di individuarli. 

Tra tutti quelli provati ne abbiamo trovato uno che, 
a nostro avviso, è molto valido ed evoluto sia co¬ 
me hardware sia come software. 

Si tratta di quello della SOFTEC di Azzano Deci¬ 
mo, in provincia di Pordenone. 

Il suo software è inoltre perfettamente compatibile 
con il sistema operativo Windows 3.1 e precedenti 
ed anche con il più recente Windows.95, laddove 
molti altri software presentano invece dei problemi. 
Nota: Il pacchetto non funziona sotto DOS. 

Utilizzando il software è possibile risolvere l’80% 
dei problemi relativi alla programmazione. 

Noi vi spiegheremo come deve essere usato per 
controllare passo per passo ogni istruzione e per 
scoprire tutti gli errori logici che potreste aver com¬ 
messo nello scrivere un programma. 




Con il software “emulatore” della SOFTEC riuscirete a programmare 
senza difficoltà tutti i micro della serie ST6210/15/20/25 perché se com¬ 
metterete qualche “errore” potrete “rintracciarlo” e correggerlo. Questo 
software funziona sotto Windows 3.1 e sotto Windows 95. 


Welcome to DSE622 In-Circuit Reai Time Emulator 


□ 

fon 

Welcome to DSE622 In-Circuit Reai Time Emulator installation 
program. Before continuing, please enteryour name andyour 
organization. 



Name: 


Company: 

Continue |\ _Exit Installation 


Fig.1 Per installare il DSE inserite il nome. 



Fig.2 Messaggio di fine installazione. 


Anche se supponiamo che tutti sappiano già come 
trasferire un programma da un floppy sull’Hard-Di- 
sk, riteniamo ugualmente utile ricordare queste po¬ 
che istruzioni. 

INSTALLARE il SOFTWARE 
sotto WINDOWS 3.1 

Se nel vostro computer avete installato Windows 
3.1 o una versione precedente, dopo aver inserito 
il dischetto del software DSE622 nel suo Drive en¬ 
trate in Program Manager, poi portate il cursore in 
alto a sinistra sulla scritta File e cliccate, quindi an¬ 
date sulla scritta Esegui, cliccate nuovamente e 
quando appare la finestra di dialogo digitate: 

A:\setup poi cliccate su OK 

In questo modo il software DSE622 verrà trasferi¬ 
to dal floppy nell’Hard-Disk. 

Quando appare la finestra Name and Company 
(vedi fig.1) inserite il vostro nome poi cliccate sulla 
scritta Continue per completare l’installazione. 















































Ad installazione avvenuta apparirà la finestra di 
fig.2: qui cliccate sulla scritta OK ed apparirà la fi¬ 
nestra di fig.3. 



fi 

DSE622 Reai Time Emulator 


DSE622 

£ 

DSE622 Help 



Fig.3 Finestra del Reai Time Emulator. 


Portate il cursore in alto a sinistra nel quadrettino 
con il segno - e cliccate per far apparire la finestra 
di fig.4. 

Ora portate il cursore sulla scritta Chiudi e clicca¬ 
te in modo che compaia la finestra del: 


Program Manager di Windows 3.1 





DSE622 Reai Time Emulator | 

Ripristina 

1 


Sposta 

Ridimensiona 

Riduci a icona 

Ingrandisci 

Chiudi CTRL+F4 

Successivo CTRL+F6 / 


Fig.4 Per chiudere potete usare CTRL+F4. 



A questo punto andate con il cursore sul simbolo 
di File Manager (vedi fig.5) e cliccate, quindi an¬ 
date sul simbolo dell’unità floppy disk A (riporta¬ 
to in alto sulla sinistra) e cliccate nuovamente. 
Appariranno così sulla destra del video queste tre 
scritte (vedi fig.6): 

atest.asm 

btest.asm 

setup.exe 

Ora dovete trasferire nell’Hard-Disk i due soli files 
atest.asm e btest.asm, perciò selezionate con il 
cursore la scritta atest.asm, andate sulla scritta Fi¬ 
le posta in alto sulla sinistra e cliccate in modo che 
appaia la finestra di fig.7. 



Principale 

File 

J2Ì 

^J, 

Mar 

Ì- j 

ìager Pannello di Print Manager 

controllo 


Fig.5 Icona di File Manager in Windows. 


Selezionate il comando copia e vedrete apparire 
la finestra di dialogo di fig.8, in cui dovete specifi¬ 
care dove volete copiare il file atest.asm. 

Portate il cursore sulla finestra in basso e scrivete: 

C:\ST6 

poi andate sulla scritta OK e cliccate. 

Tornerete così alla finestra di fig.6. 

Nota: vi abbiamo fatto copiare nella directory ST6 
questo file, perché tutti i precedenti programmi in¬ 
seriti nel dischetto DF.1170, contenenti il softwa¬ 
re di sviluppo dell’ST6 della SGS-Thomson, pre¬ 
vedevano l’installazione in questa directory. 

Ripetendo i passaggi appena descritti dovete ora 
copiare nella directory ST6 anche il file btest.asm. 

Al contrario non dovete assolutamente copiare il 
terzo file setup.exe, perché questo programma è 
già stato installato. 

Per uscire da File Manager cliccate in alto a sini¬ 
stra su File e selezionate la scritta Esci. 






































































































Installare il SOFTWARE 
sotto WINDOWS 95 

Se nel vostro computer avete installato Windows 
95, dopo aver inserito il dischetto con il software 
DSE622 nel suo Drive, cliccate sulla scritta Avvio 
posta in basso, quindi andate sulla scritta Esegui 
e cliccate nuovamente. 

Quando appare la finestra di dialogo dovete digi¬ 
tare: 

A:\setup poi cliccate su OK 

Il software DSE622 verrà direttamente installato dal 
floppy nell’Hard-Disk. 

Quando appare la finestra Name and Company 
(vedi fig.9) inserite il vostro nome, quindi andate 
sulla scritta Continue e cliccate. 

Ad installazione avvenuta apparirà la finestra di 
fig.10: ora andate sulla scritta OK e cliccate. 


F" 


DJEC/22 In-CìrcHÌiRaul TinteEtmilaior y. 1.0-1 
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Fig.9 Quando appare la finestra dell’instal¬ 
lazione del programma, inserite il vostro 
nome e cliccate su Continue. 


Quando appare la finestra visibile in fig.11, porta¬ 
te il cursore in alto a destra sull’icona con il dise¬ 
gno X e cliccate per tornare nella finestra princi¬ 
pale di Windows 95 (vedi fig.12). 



Fig.11 Per tornare alla finestra principale di 
Windows 95 cliccate sul simbolo X. 



Fig.12 Dalla finestra principale di Windows 
95 cliccate su Avvio. 


Ora cliccando sulla scritta Avvio posta in basso at¬ 
tiverete un sottomenu nel quale dovrete selezio¬ 
nare la scritta Programmi e poi Gestione risorse. 
Dopo aver selezionato anche questa scritta appa¬ 
rirà la finestra di dialogo di fig.13. 



Fig.10 Quando l’installazione sarà comple¬ 
tata comparirà un messaggio. Per conti¬ 
nuare cliccate su OK. 


File Modifica Visualizza Strumenti 2 

a (C:1 , 4 

si 1 xlmrl -l - hEllii 

Tutte li Vai a una cartella diversa| * 

Contenuto di "C:\" 


E 

ta |C:) 
ì Q Acroread 
i-dì Audiosim 
l'-Pl Bstone 

EH L_I Catalogo 

Nome | Dimensio... I Tipo | Modificato 

_|ÌAcroread ! Cartella di file 12/02/9616 

di Audiosim Cartella di file 26/01 /9611 

di Bstone Cartella di file 29/01 /9614 

_l Catalogo Cartella di file 29/01 /9613 


Fig.13 Cliccando sulla scritta Avvio, visibi¬ 
le in fig.12, e seguendo le istruzioni ripor¬ 
tate nel testo entrate nella finestra Gestio¬ 
ne Risorse di Windows 95. 


Cliccate sulla freccia che appare nella piccola fi¬ 
nestra in alto al cui interno è scritto C: per veder 















































































apparire un’altra piccola finestra nella quale dove¬ 
te selezionare la scritta: 

Floppy da 3.5 pollici A: 

Dopo aver cliccato (vedi fig.14), apparirà sulla de¬ 
stra il contenuto del dischetto floppy, cioè i tre fi- 
les: 

Atest.asm 

Btest.asm 

Setup.exe 

A questo punto dovete trasferire nell’Hard-Disk so¬ 
lo i files Atest.asm e Btest.asm. 

Per prima cosa selezionate il file Atest.asm, poi 
andate sull’icona Copia (vedi fig.15) e cliccate. 


Poiché questo file deve essere copiato nella di¬ 
rectory ST6, nella finestra a sinistra (vedi fig.16) 
cercate con il mouse la scritta ST6, quindi fermate 
il cursore su questa riga e cliccate. 

Per il momento avete selezionato la directory, ma 
il file non è ancora stato trasferito. 

Per trasferirlo andate sull’icona incolla (vedi fig.17) 
e cliccate. 

Ripetete la procedura visibile in fig.14 per copiare 
anche il secondo file Btest.asm. 

Nota: non copiate il file setup.exe perché già in¬ 
stallato. 

Per uscire da questa finestra andate in alto a sini¬ 
stra su File, poi portate il cursore su Chiudi oppu¬ 
re pigiate i tasti ALT+F4. 



I FILES ATEST e BTEST 

I programmi che vi abbiamo fatto copiare nella di¬ 
rectory ST6 ci sono serviti per nostri test di simu¬ 
lazione e ve li proponiamo in modo che possiate im¬ 
parare ad usare questo software di simulazione. 

II programma ATEST è stato concepito in modo da 
usare i quattro piedini PAO - PAI - PA2 - PA3 di 
porta A come ingressi ed i piedini PBO - PB1 - 
PB2 - PB3 di porta B come uscite. 

Applicando su uno di questi quattro ingressi un li¬ 
vello logico 1 , tramite un interruttore o un micro- 
switch ecc., vorremmo che apparisse sulla corri¬ 
spondente uscita un livello logico 1 da utilizza¬ 
re per accendere un diodo led oppure per pola¬ 
rizzare la Base di un transistor o per eccitare un 
relè o una sirena. 

Il programma BTEST differisce dal precedente so¬ 
lo perché vi abbiamo inserito alcuni errori, che ci 
permettono di mostrarvi come il software vi aiuti 
ad individuarli. 

COME lavorare con il SOFTWARE DSE622 

Come abbiamo già accennato, anche senza la 
scheda emulatrice, che la SOFTEC è in grado di 
fornire ad un prezzo molto competitivo, questo 
software permette di controllare in modo traspa¬ 
rente tutte le istruzioni di qualsiasi programma, aiu¬ 
tando così nel loro lavoro tutti i programmatori ed 
in particolar modo quelli che da poco hanno inizia¬ 
to a programmare. 

Quando si lancia il programma DSE622, il softwa¬ 
re testa se sull’uscita della porta COM2 è collega¬ 
ta la scheda emulatrice della SOFTEC. 






















































Ovviamente se non la trova segnala “ERRORE” 
(vedi fig.18), ma di questo non dovete assoluta- 
mente preoccuparvi. 


Prima di proseguire riportiamo il significato di al¬ 
cune parole che sono spesso richiamate nell’arti¬ 
colo. 


Infatti dei tre tasti selezionabili in questa finestra, 
Retry - Demo - Parameters, basterà cliccare sul 
tasto Demo per iniziare a testare il programma. 


cliccare - definiamo così l’azione che si effettua 
premendo il tasto del Mouse sulla scritta o icona 
indicata. 



Fig.18 Se non avete la scheda dà errore. 


Se cliccate sul tasto Parameters apparirà la fine¬ 
stra di fig.19, che, se un domani l’acquisterete, vi 
permette di indicare al computer su quale porta se¬ 
riale avete collegato la scheda emulatrice. 

Quando sarete in questa finestra vi consigliamo di 
cambiare la velocità di esecuzione (Baud Rate), 
e, potendo scegliere tra 9.600 - 19.200 - 28.800 - 
57.600 - 115.200 Baud, vi suggeriamo di sceglie¬ 
re la massima velocità, cioè 115.200 Baud. 
Digitate perciò questo numero poi cliccate sulla 
scritta OK. 



Fig.19 Scegliete la COM e i Baud Rate. 

Quando appare la finestra principale del software 
di simulazione (vedi fig.20) si possono già inizia¬ 
re a testare tutti i programmi. 



Fig.20 Finestra principale della SOFTEC. 


Project - chiamiamo con questa parola tutti i files 
con estensione .PRJ che, oltre le caratteristiche del 
programma, contengono le specifiche definite con 
il software simulatore per testare il programma 
stesso. 

source/file - chiamiamo con questa parola tutti i 
programmi già assemblati riconoscibili dall’esten¬ 
sione .HEX. 

simulazione - chiamiamo con questa parola l’ese¬ 
cuzione dei test dei programmi con l’ausilio del 
software DS622, senza l’utilizzo dell’Hardware 
dell’emulatore. 

variabili - chiamiamo con questa parola le defini¬ 
zioni degli indirizzi di memoria Data Space. 

COME creare la LIBRERIA per l’ST6 

Quando sul monitor appare la finestra con i menu 
(vedi fig.20), per creare la libreria cliccate sulla 
scritta Configure e vedrete apparire la piccola fi¬ 
nestra visibile in fig.21. 

- Cliccate sulla riga Tools per far apparire la fine¬ 
stra di dialogo visibile in fig.22. 




































































































- Cliccate sulla scritta Add per far apparire la fine¬ 
stra di dialogo di fig.23. 


- Nel riquadro a destra cliccate sulla riga C:\ e, sem¬ 
pre in questo riquadro, ricercate la directory ST6, 
quindi andate con il cursore su questa riga e clic¬ 
cate. 

- Nel riquadro a sinistra cercate il programma 
ST6.EXE (vedi fig.24) e selezionatelo, poi uscite 
cliccando su OK. 

In questo modo nel riquadro Command Line (ve¬ 
di fig.25) apparirà: C:\ST6\ST6.EXE 

- Nella riga Menu Title dovete digitare: ST6 

- Nella terza riga, Arguments (vedi fig.25), dovete 
digitare: $2 



Fig.24 Selezionate il programma ST6.EXE. 



Fig.25 Digitate nelle righe quanto appare. 


Definite tutte le specifiche richieste, tornate al me¬ 
nu principale (vedi fig.20) cliccando su OK. 

In questo modo vi abbiamo fatto inserire nella li¬ 
breria il programma ST6\ST6.EXE, che già da tem¬ 
po vi abbiamo fornito. Con questo programma po¬ 
trete assemblare, scrivere, correggere, ricercare un 
programma, come vi abbiamo spiegato nelle lezio¬ 
ni precedenti (vedi riviste N.172/173 - 174 - 
175/176). 

COMPILARE in ASSEMBLER 
il programma ATEST.ASM 

Quando sul monitor appare la finestra con i menu 
(vedi fig.20) selezionate la riga Tools. 

Nella piccola finestra che appare (vedi fig.26) clic¬ 
cate sulla scritta ST6 e così apparirà la finestra dei 
programmi di sviluppo dell’ST6, visibile in fig.27. 

Per aprire la finestra dei files pigiate il tasto F3 op¬ 
pure andate sulla scritta OPEN e cliccate (vedi 
fig.28). 

Ora cercate il programma: 

atest.asm 

e quando l’avete trovato cliccate sulla scritta, poi 
andate su OPEN e cliccate nuovamente. 
Appariranno così sul monitor tutte le istruzioni di 
questo programma (vedi fig.29). 

A questo punto portate il cursore sulla scritta ST6 
(prima riga in alto) e cliccate. 

Sotto questa scritta si aprirà una finestra (vedi 
fig.30) con il cursore già posizionato sulla parola 
Assembla quindi cliccate. 

Durante la compilazione in assembler verranno 
creati questi files: 

ATEST.HEX 

ATEST.SYM 

ATEST.DSD 

Per chi ancora non conoscesse il significato di que¬ 
ste estensioni, lo accenniamo qui brevemente: 

.HEX - programma eseguibile in formato Intel-Hex. 

.SYM - file contenente le definizioni delle etichet¬ 
te di salto ed il relativo indirizzo di memoria Pro¬ 
gram Space 

.DSD - file contenente le definizioni delle variabi¬ 
li, le loro caratteristiche ed il relativo indirizzo di me¬ 
moria Data Space. 




Cartelle: 

c:\dse622 


c: ^ 

d 

(^3 dse622 
f 1 examples 

d 


Tjpo file: IJnità: 

jExecutable (*.exe) ^ | Q c: 


-Ll-Xj 




Fig.23 Finestra dialogo ADD TOOL. 











































































Fig.26 Cliccate sul sottomenu ST6 di Tools. 



Fig.27 Finestra di sviluppo per micro ST6. 



Fig.28 Aprite un programma pigiando F3. 



Fig.29 Vedrete sul monitor le istruzioni. 



Fig.30 Cliccate sul sottomenu Assembla. 


Completata la compilazione potete premere un 
qualsiasi tasto per rientrare nell’Editor dell’ST6, e 
quando apparirà la finestra di fig.29 cliccate sulla 
scritta ALT-F3 oppure premete i tasti ALT+F3. 
Apparirà un’altra finestra (vedi fig.27) in cui dovre¬ 
te digitare Alt X per uscire dal programma ST6 e 
rientrare automaticamente nel software DS622. 


Quando appariranno i menu del DS622 selezio¬ 
nate il menu Project e, nella finestra che appare 
visibile in fig.31, andate sulla scritta New Project 
e cliccate. 


Questa operazione serve per creare il file con e- 
stensione .PRJ, che verrà utilizzato dal simulato¬ 
re per testare il programma. 


Quando appare la finestra di fig.32, digitate nella 
riga Project name il nome del file ATEST (non è 
necessario riportare dopo il nome l’estensione 

.PRJ). 

Tenete presente che potete anche cambiare nome 
al file project, cioè dargli un nome differente dal 

source file. 

In altre parole potrete ad esempio cambiare il no¬ 
me ATEST in BAUBAU o PLUTO, ma se volete e- 
vitare che un domani non vi ricordiate più quale no¬ 
me avevate scelto, vi consigliamo di mantenere lo 
stesso nome del programma assemblato, cioè nel 
nostro caso ATEST. 

Dopo aver digitato il nome portate il cursore sulla 
parola Create (vedi fig.33) e cliccate. 



Fig.31 Comando per creare il file .PRJ. 



Fig.32 Digitate il nome del project. 



Fig.33 Scegliete Create e vedrete la fig.34. 








































































































Apparirà la finestra di dialogo Edit Project (vedi 
fig.34) in cui è molto importante inserire le specifi¬ 
che richieste senza commettere errori. 



Fig.34 Digitate le specifiche richieste. 

Portate il cursore nella finestra Device e cliccando 
la “freccia in giù” cercate la sigla del micro ST6 che 
volete utilizzare. Ammesso che questo sia un 
ST6210 andate sulla riga ST6210 (vedi fig.35) e 
cliccate. 



Ora portate il cursore nella finestra Frequency (ve¬ 
di fig.36) dove potete selezionare la frequenza del 
quarzo utilizzato per il clock del micro scegliendo 

tra 8 - 4 - 2 -1 MHz. 

Nota: Se non possedete la scheda emulatrice del¬ 
la Softec scegliete a caso una di queste quattro 
frequenze. 

Per completare i dati da inserire in questa finestra 
cliccate nel cerchietto accanto alla scritta Intel-Hex 
(vedi fig.37) cosicché apparirà un punto. 



2 ^ 



Fig.36 Scegliete la frequenza del quarzo. 


Source file 


Binary 

Filename: 


f* Intel-Hex 


Brow 


Fig.37 Con Intel-Hex vedrete i file .EXE. 


In questo modo indicate al programma di visualiz¬ 
zare i soli files con estensione .HEX. 

A questo punto cliccate sulla scritta Browse in mo¬ 
do che appaia la finestra di dialogo di fig.38. 

Nel riquadro posto a destra cliccate sulla riga C:\, 
poi cercate la scritta C:\ST6 e quando l’avete tro¬ 
vata selezionatela cliccando. 

Nel riquadro a sinistra appariranno tutti i files con 
estensione .HEX. 

Cercate tra questi la scritta ATEST.HEX (vedi 
fig.39), cliccate su questa riga, poi uscite cliccan¬ 
do su OK. In questo modo nel riquadro Filename 
(vedi fig.40) apparirà la scritta: 

C:\ST6\ATEST. HEX 



Fig.38 Finestra di dialogo Browse. 



Fig.39 Quando siete nella finestra Browse, 
selezionate il file ATEST.EXE. 



Fig.40 Nel riga Filename apparirà il nome 
del file selezionato nella finestra Browse. 


Ora potete passare al Debug Information (vedi 
fig.34) e se aH’interno del cerchietto posto a sini¬ 
stra della scritta ST format trovate già un punto 
(vedi fig.42) non dovrete cliccare. 
















































































































































7 6 5 1 3 2 1 0 Wiile only I 0K H 

rrrrrrrr 

Cancel 

□ SG Enable Oscillator Safe Guaid - 1 

WTD Hardware Watchdog Activation 

TMR TIMER Pin Pull-up 

NMI NMI Pin Pull-up 

DEV 28 Pin Device Selection 

STOP Disable External Stop Mode 

OSC Crostai Oscillator 

PROT EPROM Readout Protection 


Fig.41 Se siete in simulazione, il WTD, 
Hardware Watchdog Activazion, non serve. 



Fig.42 Per creare un file con estensione 
.PRJ, cliccate sulla scritta OK. 



Fig.43 Nella videata principale del DSE622 
vengono attivate tre finestre. 



The source program is out of date. 
Update it? 

: sigi m° I 



Fig.44 Dalla finestra di fig.27 si passa con 
ALT+X a questa finestra. Per andare nella 
finestra di fig.45 cliccate su SI. 


Se per errore cliccate all’Interno del cerchietto po¬ 
sto a sinistra della scritta None facendo apparire 
un punto, durante l’esecuzione del programma 

non riuscirete a vedere i nomi delle variabili o 
delle etichette utilizzate, quindi vi sarà molto più 
difficile controllare passo per passo il programma. 

Ora cliccate sulla scritta Modify per far apparire la 
finestra di fig.41 che ha in evidenza questa scritta: 

WTD = Hardware Watchdog Activazion 

Siccome ci troviamo in simulazione, questa sele¬ 
zione non serve perciò portate il cursore su OK e 
cliccate per far apparire la finestra di fig.42. 

A questo punto cliccando sulla scritta OK verrà 
creato il Project ATEST.PRJ nella directory 
DES622 e sarete pronti per testare il programma 
(vedi fig.45). 

Se sul video appare invece una di queste scritte: 

source file not found 
symboi table file not found 
debugger file not found 

potreste aver involontariamente cancellato dei fi- 
les di compilazione. Per rigenerarli dovete cliccare 
su OK per far riapparire la finestra di fig.43. 

Ora dovete cliccare nuovamente sulla scritta Tools 
e ripetere tutte le operazioni visualizzate dalla fig.20 
alla fig.29 e vi ritroverete nella finestra visibile in 
fig.27. 

Per uscire digitate Alt+X e sul video vedrete ap¬ 
parire la finestra di fig.44. 

Cliccando su SI potrete vedere la finestra di fig.45 
con tutti i dati e le istruzioni corrette. 

































































































































Se invece appare la scritta: 

C:\ST6\ATEST.HEX emulation buffer overflow 

significa che avete scritto il programma per un tipo 
di micro ST6 diverso da quello selezionato nella ri¬ 
ga del Device (vedi fig.35). 

Ad esempio potreste aver scritto un programma per 
il micro ST62/10 ed aver inserito nel Device il mi¬ 
cro ST62/25 o viceversa. 

In presenza di questo errore cliccate su OK e, quan¬ 
do appare la finestra di fig.43, selezionate il menu 
Project e cliccate su Edit project (vedi fig.46). 

Vi ritroverete nella finestra di fig.35 dove potrete 
correggere la scritta corrispondente alla riga Devi¬ 
ce digitando la sigla corretta del micro utilizzato. 
Per uscire cliccate su OK. 



Quando apparirà la finestra di fig.45 sarete pronti 
per effettuare la simulazione del programma A- 
TEST.HEX utilizzando il file Projet ATEST.PRJ. 


Prima di proseguire è necessario che vi spieghia¬ 
mo cosa contengono le 3 finestre visibili in fig.45. 

Nella finestra Disassembler, sotto le due colonne 
Label e Mnemonic, avete le istruzioni del pro¬ 
gramma da testare in formato leggibile. 

Nelle colonne Add e Opcode appaiono le mede¬ 
sime istruzioni in formato Intel.Hex. 

Nella finestra Register appaiono tutti i registri, lo 
stack level, gli stati dei tre flags ed il valore del 

Program Counter. 

Nella finestra Data appare il contenuto del Data 
Memory Space del micro, cioè il contenuto delle 

variabili, dei registri e della Data Rom Windows 

definiti in questo programma. 

Avendo sottocchio tutte queste finestre sarete in 
grado di controllare passo x passo in simulazio¬ 
ne tutti i vostri programmi. 

Prima di iniziare il controllo, è a nostro parere ne¬ 
cessario configurare ulteriormente il software 
DS622 così da vedere sul monitor in tempo reale 
anche altre funzioni che potrebbero risultarvi mol¬ 
to utili. 



Fig.47 Aprite la finestra Code-Memory. 



Fig.48 Aprite la finestra Stack-Window. 



Fig.49 Aprite la finestra Watch. 



Fig.50 Sul video appaiono altre finestre. 


Perciò dopo aver portato il cursore sulla scritta Win- 
dow posta in alto (vedi fig.47) cliccate e nella fi¬ 
nestra che appare selezionate la riga Code Me¬ 
mory. 

Cliccate nuovamente sulla scritta Window e sele¬ 
zionate la scritta Stack Windows (vedi fig.48). 






















































































































Ritornate nuovamente a cliccare sulla scritta Win¬ 
dows e selezionate la riga Watch (vedi fig.49). 

Il sottomenu di Window sparirà. 

In questo modo alle finestre che già apparivano nel¬ 
la fig.45 si aggiungono 3 supplementari finestre 
operative (vedi fig.50), e cioè: 

Stack 

Code Memory 
Watch 

Vi consigliamo di rimpicciolire e spostare le finestre 
(vedi l’esempio riportato in fig.51) in modo da ave¬ 
re sempre sottocchio tutte le specifiche relative al¬ 
la programmazione di qualsiasi micro ST6. 



Dopo aver posizionato le finestre nei punti che ri¬ 
tenete più opportuni, tutte le volte che richiamere¬ 
te il file ATEST.PRJ o altri files con la stessa e- 
stensione, le finestre riappariranno dove le aveva¬ 
te posizionate. 

La finestra Stack permette di visualizzare in tem¬ 
po reale il valore dei suoi 6 registri. 

Se nel corso del programma viene eseguita l’istru¬ 
zione Cali (vedi rivista N.174) o viene attivato un 
Interrupt (vedi rivista N.175/176), il contenuto dei 
primi 5 registri di Stack viene immediatamente 
shiftato di un livello superiore , vale a dire che il 
contenuto del 5° registro viene passato al 6°, il con¬ 
tenuto del 4“registro viene passato al 5°e così via. 

A questo punto nel 1 ° registro di Stack viene me¬ 
morizzato il contenuto del Program Counter, cioè 
l’indirizzo di ritorno della subroutine richiamata nel¬ 
la Cali (istruzione Ret) o nell’lnterrupt (istruzione 
Reti), come appare visibile in fig.89. 


In questo modo è possibile eseguire più subroutine, 
una aH’interno dell’altra, fino ad un massimo di 6. 

La finestra Code Memory permette di visualiz¬ 
zare in esadecimale il contenuto della Program 
Memory Space, cioè la memoria del micro in cui 
sono contenute le istruzioni del programma sot¬ 
to test. 

La finestra Watch, che inizialmente è vuota, ser¬ 
ve per inserire, come poi vi spiegheremo, le va¬ 
riabili delle quali ci interessa controllare il conte¬ 
nuto per vedere come questo si modifica durante 
l’esecuzione del programma. 

Se di queste tre finestre volete che ne appaia una 
sola o due, dovete annullare una delle operazioni 
riportate nelle figg.47-48-49. 

ESEMPI di EMULAZIONE 

Le prime volte che userete il software simulatore 
DSE622 vi consigliamo di stampare il listato del 
programma che volete testare (nel nostro esem¬ 
pio ATEST.ASM) per poter confrontare le istruzio¬ 
ni stampate con quelle che appariranno sul moni¬ 
tor. 

Se avete spento e riacceso il computer, per richia¬ 
mare il programma ATEST già creato come file 
Project, che ora si chiamerà quindi ATEST.PRJ, 
dovrete cliccare sull’icona apri file (vedi fig.52). 



Nella finestra di dialogo che appare, sotto il Nome 
file ci sarà la scritta *.PRJ e nella finestra sotto¬ 
stante il solo file ATEST.PRJ, perché per ora è sta¬ 
to creato un solo project. 

Man mano che creerete files con estensione .PRJ 
troverete tutti i loro nomi in questa finestra. 

Cliccate sul nome del file desiderato quindi uscite 
da questa finestra cliccando su OK. Apparirà la fi¬ 
nestra visibile in fig. 51. 

Sull’ultima riga visibile della finestra Disassembler 
(vedi fig.53) potete vedere una riga blu evidenzia¬ 
ta da una freccia rossa. 

Nota: la freccia rossa mette in evidenza la prima 
istruzione che il programma eseguirà. 

















































Fig.53 La freccia mostra da dove si parte. 



Fig.54 Finestra Registers. 



Fig.55 Icona per avanzare passo/passo. 
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Fig.56 Aprite la fig.57 con Add Watch. 



Fig.57 Per le variabili cliccate sulla freccia. 



Fig.58 Selezionate la variabile che volete. 


Le righe sopra quella evidenziata in blu sono quel¬ 
le che abbiamo definito nel programma ATEST per 
i vettori di interrupts. 

Nella finestra Register di fig.54 appare lo Stack le- 
vel, i tre Flags NORM - INT - NMI tutti a livello lo¬ 
gico 0, ed il PC (Program Counter) posizionato sul 
valore esadecimale FFEH (come già sapete la let¬ 
tera H significa esadecimale), che corrisponde 
aH’indirizzo della prima istruzione eseguibile (vedi 
la finestra Disassembler di fig.53). 

Per far partire il programma in modo che ogni i- 
struzione avanzi passo x passo dovete portare il 
cursore sull’icona di fig.55 e cliccare. 

Ogni volta che cliccherete su questa icona il pro¬ 
gramma eseguirà una sola istruzione e questo vi 
consentirà di controllarlo riga per riga. 

Come vi spiegheremo tra poco, è possibile ese¬ 
guire anche più istruzioni per ogni passo oppure 
lanciare un’esecuzione in automatico. 

La prima istruzione che il programma ATEST e- 
segue è quella riportata all’indirizzo FFEH, come 
appare in fig.53. 

INSERIRE una VARIABILE 
nella finestra WATCH 

Poiché potrebbe risultare utile controllare lo stato 
dei piedini della porta A di entrata (input) e quello 
dei piedini della porta B di uscita (output), scri¬ 
vendo nella finestra Watch le definizioni di queste 
variabili potrete averle sempre sottocchio. 

In questo modo sarà più facile vedere come cam¬ 
biano man mano che fate avanzare il programma. 

Per visualizzare le due porte nella finestra Watch 
dovete eseguire queste semplici operazioni: 

- Andate con il cursore nella finestra Watch e clic¬ 
cate per evidenziare questa finestra. 

- Come potete notare, nella barra dei menu posta 
in alto, tra le scritte Tools e Configure, appare la 
scritta Watch che vi permette di accedere ad un 
sottomenu dedicato a questa finestra. 

Tra le scritte Tools e Configure appare infatti di 
volta in volta il menu relativo alla finestra posta in 

primo piano. 

- Cliccate sulla scritta Watch e selezionate la scrit¬ 
ta Add Watch (vedi fig.56) in modo da far appari¬ 
re la finestra di dialogo visibile in fig.57. 














































































- Andate con il cursore sulla freccia posta a destra 
della scritta Variable e vedrete apparire in ordine 
alfabetico l’elenco delle variabili presenti nel pro¬ 
gramma ATEST (vedi fig.58). 

Cliccate su port_a, poi andate su ADD e qui cuc¬ 
cate. In questo modo nella finestra Watch apparirà 
la variabile port_a con l’indirizzo ADD di Data 
Space, il valore esadecimale - Hex ed il valore de¬ 
cimale - Dee (vedi fig.59). 

Poiché ci interessa controllare anche i valori della 
porta B, dovrete ripetere tutte le operazione ripor¬ 
tate nelle figg.56-57-58, quindi selezionare la va¬ 
riabile port_b. 

Cliccando poi su ADD nella finestra Watch appa¬ 
riranno i dati della port_b (vedi fig.60). 

COME INSERIRE un BREAKPOINT 

Un’altra operazione che dovete imparare è come 

attivare un breakpoint. 

Attivare un breakpoint significa mettere un punto 
di blocco ad un’istruzione del programma in modo 
che durante la simulazione si fermi su quella riga. 

Ammesso che vogliate inserire un breakpoint 
sull’ultima riga in basso in cui è riportata l’istru¬ 
zione (vedi fig.61): 

898 OD D4 00 Idi tscr,00H 

dovrete portare il cursore su questa riga e clicca¬ 
re due volte. Vedrete così apparire sul monitor la 
finestra di comando visibile in fig.62. 

Cliccate sulla scritta Toggle Breakpoint e a sini¬ 
stra della riga selezionata comparirà un punto e- 
sclamativo che vi segnala che su quella riga è sta¬ 
to attivato il breakpoint (vedi fig.63). 


COME usare il BREAKPOINT 

Come già vi abbiamo accennato, il breakpoint ser¬ 
ve per fermare il programma sulla riga di istruzio¬ 
ne che avete marcato ogni volta che verrà lancia¬ 
ta una simulazione in modo automatico o a pas¬ 
si multipli. 

Potete mettere quanti breakpoint volete, cioè 3 - 

5-14-20 ecc. 

È sottinteso che quando il programma si sarà fer¬ 
mato su un breakpoint per proseguire dovrete nuo¬ 
vamente cliccare sull’icona passo per passo o a 
passi multipli oppure sull’esecuzione automatica. 
Per togliere il breakpoint (ma ora non toglietelo 
perché ve lo faremo usare per fare un po’ di prati¬ 
ca) dovrete andare sulla riga interessata e clicca¬ 
re due volte, poi nella finestra che appare dovre- 


FF FF FF 
FF FF FF 
FF FF FF 
FF FF FF 




Fig.59 Esempio della Variabile port_a. 



Fig.60 Esempio della Variabile port_b. 



Fig.61 Finestre per testare il programma. 
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Fig.62 Per attivare un Breakpoint. 



Fig.63 Dove c’è ! è attivato un Breakpoint. 















































































































te andare sulla scritta Toggle Breakpoint (vedi 
fig.62) e cliccare. 

in questo modo il breakpoint verrà eliminato dalla 
riga in cui in precedenza era stato inserito. 

Se per errore andate sulla scritta Cancell e cuc¬ 
cate non toglierete il breakpoint, ma farete solo 
sparire la finestra di fig.62. 

ESECUZIONE in AUTOMATICO 

Per far avanzare in modo automatico le istruzioni 
senza cliccare tutte le volte il tasto del passo-pas¬ 
so riportato in fig.55, dovete portare il cursore sull’i¬ 
cona visibile in fig.64, cioè sull’immagine di una pa¬ 
gina con una freccia rivolta verso il basso. 



Cliccando su questa icona ottenete un’esecuzione 
sequenziale ed automatica di tutte le istruzioni, che 
si fermerà solo sull’istruzione in cui avete inserito 

il Breakpoint. 

Quando viene eseguita l’istruzione: 

883 OD CO OF Idi port_a,0FH 

se guardate nella finestra Watch al contenuto del¬ 
la port_a sotto la colonna Dee. trovate il numero 

15. 

Quando viene eseguita l’istruzione: 

88C OD CI OF Idi port_b,0FH 

se guardate nella finestra Watch al contenuto della 
port_b sotto la colonna Dee. trovate il numero 15. 
Infatti sempre nella finestra Watch al numero esa- 
decimale OF corrisponde il numero decimale 15. 
Se non sapete ancora convertire un numero deci¬ 
male in un numero binario vi consigliamo di an¬ 
dare a pag.381 del nostro Handbook (se ne siete 
sprovvisti potete richiedercelo) dove troverete: 

0000-1111 

Per avere una riprova visiva di queste condizioni 
logiche dovete andare nella finestra Data. 

Questa finestra riporta nella prima colonna gli indi¬ 
rizzi di memoria e nel righello in alto in grigio i va¬ 
lori esadecimali: 

00-01-02-03-04-09-0A-0B-0C-0D-0E-0F 


Poiché l’indirizzo di port_b è CI, nella prima co¬ 
lonna dovrete cercare l’indirizzo di memoria CO, 
poi, prendendo come riferimento il righello in gri¬ 
gio, scendete dal valore esadecimale 01 fino ad in¬ 
contrare la riga CO, come si farebbe con una Ta¬ 
vola Pitagorica, e così troverete il valore 0F. 

Portate il cursore su 0F poi cliccate 2 volte e ve¬ 
drete apparire la finestra di dialogo Edit data ri¬ 
portata in fig.65. 

Cliccando sulla scritta Bits apparirà sullo schermo 
la finestra di dialogo di Port B Data Register di 
fig.66. 



In orizzontale potete leggere i numeri 7 - 6 - 5 - 4 
-3-2-1-0, che corrispondono ai piedini della 
porta B. Sotto questi numeri ci sono delle caselle 
che possono contenere una V oppure risultare vuo¬ 
te. 

Nel nostro caso la V è presente solo sulle prime 
quattro caselle 3 - 2 -1 - 0, mentre nelle altre quat¬ 
tro caselle 7 - 6 - 5 - 4 non appare nulla. 

Le caselle con la V sono quelle che si trovano a li¬ 
vello logico 1 , cioè sui piedini corrispondenti ri¬ 
sulta presente una tensione positiva, ed ovvia¬ 
mente quelle senza la V sono a livello logico 0. 
Come già saprete il numero decimale 15 corri¬ 
sponde aOOOO-llllin binario. 

Nella colonna verticale troverete gli otto piedini 
della porta B siglati PB0 - PB1 - PB2 - PB3 - PB4 
- PB5 - PB6 - PB7. 

Da questa finestra di dialogo potete dunque sape¬ 
re quale condizione logica è presente sugli otto 
piedini. 










































Nel nostro esempio: 

PB7 - PB6 - PB5 - PB4 = livello logico 0 
PB3 - PB2 - PB1 - PBO = livello logico 1 

Dopo questa verifica potete cliccare su OK, poi cuc¬ 
cate ancora su OK nella successiva finestra e tor¬ 
nerete nella finestra Data di fig.67. 

IMPORTANTE 

Durante l’esecuzione del programma tutte le quat¬ 
tro uscite si portano a livello logico 0 fino a quan¬ 
do uno dei quattro ingressi non viene collocato a 

livello logico 1. 

Potendo vedere nella finestra di fig.66 le condi¬ 
zioni logiche presenti sulle porte, vi accorgerete 
subito se nel programma è stato commesso un er¬ 
rore. 

Ammesso infatti che nel piedino PB6 di porta B 
debba risultare presente un livello logico 1 e non 
un livello logico 0 e nel piedino PBO i porta B un 
livello logico 0 e non un livello logico 1, potrete 
subito vedere la situazione sui piedini della porta. 
La finestra di fig.66 non solo vi permette di vedere 
i livelli logici sui piedini di port_b, ma anche di 
correggerli. Infatti se, ad esempio, provate a clic¬ 
care nella casella 6 comparirà una V che vi indica 
che questo piedino è passato a livello logico 1. 

Poiché il programma ATEST non contiene errori 
non cambiate i livelli logici su PBO - PB1 - PB2 - 

PB4 e se lo fate, rimettete quelli che apparivano in 
precedenza, diversamente andrete a modificare il 
corretto proseguimento del test. 

Allo stesso modo potrete controllare il livello logi¬ 
co del registro di controllo dell’AD/Converter (nel 
programma di ATEST l’AD/Converter non viene u- 
sato). 

Andate nella finestra Data (vedi fig.67) e cercate 
negli indirizzi di memoria il valore esadecimale DO. 

Poiché l’indirizzo di questo registro è DI, pren¬ 
dendo come riferimento il righello in grigio, poi 
scendete dal valore esadecimale 01 fino ad incon¬ 
trare la riga DO e troverete il valore 00. 


Ponendo il cursore su 00 e cliccando due volte ve¬ 
drete apparire la finestra dell’Edit data di fig.68, ov¬ 
viamente diversa da quella di fig.65. 

Cliccando sulla scritta Bits apparirà la finestra di 
fig.69, leggermente diversa da quella di fig.66. 



Dopo avervi spiegato come sia possibile controlla¬ 
re visivamente i livelli logici presenti sui piedini 
del micro, potrete divertirvi a vedere il contenuto 
delle variabili e dei registri che non vi abbiamo ci¬ 
tato. In questo modo farete un po’ di pratica che vi 
servirà in futuro per scrivere correttamente i vostri 
programmi. 


ESECUZIONE a PASSI MULTIPLI 

Per la funzione passi multipli sarebbe consiglia¬ 
bile togliere tutti i breakpoints, in ogni caso anche 
se li lascerete potrete ugualmente eseguire questa 
funzione. 

L’esecuzione a passi multipli vi dà la possibilità di 
eseguire in modo automatico un numero di istru¬ 
zioni che voi stessi potrete definire. 

Ad esempio, potrebbe risultarvi comodo far ese¬ 
guire al programma 5-8-10 istruzioni di segui¬ 
to prima i fermarvi per controllare i dati. 

Stabilito il numero di istruzioni da eseguire di se¬ 
guito, tutte le volte che cliccherete sull’icona di 
fig.70 verrà eseguito il numero di istruzioni che a- 
vete prefissato. 




SÉ: Data 



Fig.67 Per attivare la finestra di dialogo 
Edit Data dovete cliccare due volte su 00. 













































Attualmente il software è predefinito per fare pas¬ 
si di 2 sole istruzioni, quindi ammesso che desi¬ 
deriate fare dei passi di 5 istruzioni dovrete pro¬ 
cedere come segue. 

- Portate il cursore sulla scritta Run visibile in fig.71 
e cliccate e nella finestra che appare andate sulla 
scritta Multiple Step Value e cliccate. 



Fig.70 Icona per fare passi multipli. 



Fig.71 Finestra per variare i passi/multipli. 


- Nella finestra di dialogo che appare (vedi fig.72) 
andate nella casella Value e sostituite il numero 2 
con il 5, poi andate su OK e cliccate. 



Fig.72 Digitate il numero dei passi multipli. 


- Tutte le volte che cliccherete sull’icona in cui so¬ 
no disegnate due orme (vedi fig.73), il programma 
avanzerà di 5 istruzioni. 

Cliccando nuovamente sull’icona, il programma a- 
vanzerà di altre 5 istruzioni. 



Fig.73 Icona per i passi multipli. 


FUNZIONE DEBUG 

La funzione debug è molto utile per vedere la map¬ 
pa del micro utilizzato e su quali piedini sono po¬ 
sizionate le porte A - B - C, inoltre potete vedere 
quali livelli logici sono presenti sui piedini d’in¬ 
gresso o di uscita durante l’esecuzione del pro¬ 
gramma. 

Per entrare nella funzione debug cliccate sulla 
scritta Debug, visibile nella fascia superiore del me¬ 
nu, e quando appare la maschera di fig.74 clicca¬ 
te nella riga Test I/O. 

Apparirà così la finestra di fig.75. 

In alto potete leggere la sigla dell’integrato pre¬ 
scelto, nel nostro caso ST6210 - ST6220, in bas¬ 
so a sinistra potete vedere le connessioni del mi¬ 
cro e su quali piedini sono posizionate le porte A 
e B, infine sul lato destro è visibile la mappa di con¬ 
figurazione logica di queste due porte. 

Per la porta A, che dispone di soli 4 piedini PAO - 
PAI - PA2 - PA3, troverete a destra 4 caselle gri¬ 
gie (questo perché i piedini della porta A sono so¬ 
lo 4) e 4 caselle indicate 3 - 2 -1 - 0 che possono 
essere vuote o contrassegnate da una V. 



Fig.74 Cliccate su Test I/O per la fig.75. 



Fig.75 Mappa di configurazione del micro. 


caselle DDR - (Data Direction Register) Se que¬ 
ste caselle risultano vuote significa che abbiamo 
definito i piedini input (ingressi), quelle contrasse¬ 
gnate con una V indicano che li abbiamo definiti 
output (uscite). 

caselle DR - (Data Register) Se queste caselle ri¬ 
sultano vuote significa che sui piedini è presente 
un livello logico 0, se sono contrassegnate da u- 
na V significa che è presente un livello logico 1. 























































































caselle OR - (Opzion Register) Queste caselle 
servono per selezionare le varie opzioni delle por¬ 
te. Se con il DDR abbiamo predefinito il piedino co¬ 
me input, combinandolo con il DR e l’ÒR otterre¬ 
mo queste selezioni: 


caselle OR - (Opzion Register) Queste caselle 
servono per selezionare le varie opzioni delle por¬ 
te. Se con il DDR abbiamo predefinito il piedino co¬ 
me output, combinandolo con il DR e l’OR otter¬ 
remo queste selezioni: 


DDR DR OR opzione come ingressi 


DDR DR OR opzione come uscite 


0 

0 

0 

0 


0 0 pull-up senza interrupt 

1 0 senza pull-up e senza interrupt 

0 1 con pull-up e con interrupt 

1 1 ingresso analogico (vedi nota) 


Nota: L’ingresso analogico non è consentito per i 
piedini PAO - PAI - PA2 - PA3. 


10 0 Collettore aperto 

110 Collettore aperto 
10 1 uscita in Push-Pull 

Poiché in molti programmi non si usano i termini D- 

DR - DR - OR, ma PDIR - PORT - POTP, riportia¬ 
mo le loro equivalenze: 


Per la porta B, che dispone di 8 piedini PBO - PB1 

- PB2 - PB3 - PB4 - PB5 - PB6 - PB7, vedrete 8 
caselle su 3 file indicate 7-6-5-4-3-2-1 - 

0 che possono essere vuote o contrassegnate da 
una V. 

caselle DDR - (Data Direction Register) Se que¬ 
ste caselle risultano vuote significa che abbiamo 
definito i piedini input (ingressi), quelle contrasse¬ 
gnate con una V indicano che li abbiamo definiti 
output (uscite). 

caselle DR - (Data Register) Se queste caselle ri¬ 
sultano vuote significa che sui piedini è presente 
un livello logico 0, se sono contrassegnate da u- 
na V significa che è presente un livello logico 1. 


PDIR corrisponde a DDR 

PORT corrisponde a DR 

POTP corrisponde a OR 

Se rileggerete tutti gli articoli precedenti riguardan¬ 
ti I ST6 (vedi Riviste N.172/173-174-175/176) tro¬ 
verete molti esempi su come procedere per setta- 
re le porte come ingressi e uscite. 


Potendo vedere tramite la finestra visibile in fig.75 
tutti i livelli logici presenti su questi piedini, pote¬ 
te comprendere quanto risulti semplice accorgersi 
degli errori, anche perché proseguendo passo x 
passo potete subito verificare come cambiamo i li¬ 
velli logici sia sugli ingressi sia sulle uscite. 



Questo software vi permetterà di vedere nella finestra Disassembler tutte le istruzioni in 
formato leggibile; nella finestra Register tutti i registri, lo stack level e gli stati dei flags; 
nella finestra Data il contenuto delle variabili dei registri e della data rom Windows ecc. 
Chi desiderasse acquistare la scheda emulatrice (vedi foto) può rivolgersi a: 

SOFTEC MICROSYSTEMS V.le Rimembranze, 19/C 33082 AZZANO DECIMO (PN) 
fax 0434-631598 - tei. 0434-640113 - BBS 0434-631904 














































Nel disegno grafico visibile sulla sinistra di fig.75, 
potete vedere i piedini che hanno una casella gri¬ 
gia, ad esempio: 

1 = Vdd (tensione positiva di alimentazione) 

2 = Timer 

3 = Oscillatore input 

4 = Oscillatore uscita 

5 = NMI (Interrupt non mascherato) 

6 = TEST (piedino di programmazione) 

7 = Reset 

20 = Vss (tensione negativa di alimentazione) 


Le caselle grigie non possono essere direttamen¬ 
te testate nella simulazione tramite software, per¬ 
ché manca la tensione di alimentazione ed il 
quarzo, quindi dovrete attivarle con alcuni accor¬ 
gimenti. 

A esempio, non disponendo della frequenza di 
clock potrete simulare le funzioni di timer solo at¬ 
tivando da programma la subroutine legata all’in- 

terrupt del timer. 

La funzione di reset può essere invece attivata con 
un comando presente nella barra dei menu. 

Chi si procurerà la scheda emulatrice sarà in gra¬ 
do di testare in modo automatico anche queste fun¬ 
zioni, perché ha la stessa funzione del micro. 

In ogni caso risolverete molti problemi già con il so¬ 
lo software. 

Ad esempio se avete scritto un programma che de¬ 
ve portare a livello logico 1 il piedino 6 e simu¬ 
landolo vi accorgete che è rimasto a livello logico 
0, vi sarà molto più facile, avanzando passo per 
passo e controllando ogni istruzione, trovare quel¬ 
la che, per un banale errore, non ha provveduto a 
modificare il livello logico su tale piedino. 


Per uscire dal debug è sufficiente portare il curso¬ 
re sulla scritta OK poi cliccare. 

Il programma ripartirà automaticamente dalla pri¬ 
ma istruzione eseguibile. 

Se lancerete l’esecuzione automatica vedrete il 
programma ruotare all’infinito sulle etichette: 

ripeti 

mainOO - mainsl - mainOI - mains2 
main02 - mains3 - main03 - mains4 

perché non trova premuto nessuno dei quattro in¬ 
terruttori presenti sulla porta A. 


COME SIMULARE NNTERRUTTORE 

Nel programma ATEST tutte le uscite rimangono a 
livello logico 0 fino a quando non mettete a livel¬ 
lo logico 1 uno dei quattro ingressi. 

Poiché siamo in simulazione e non avete né un 
“interruttore” né una tensione “positiva”, per porta¬ 
re a livello logico 1 uno di questi ingressi dovre¬ 
te forzare l’ingresso desiderato come ora vi spie¬ 
gheremo. 

Cliccate sull’icona di Stop visibile in fig.76 rappre¬ 
sentata da una mano aperta. 



Ammesso di voler portare a livello logico 1 l’in¬ 
gresso del piedino PA2 di port_a affinché sull’u¬ 
scita del piedino PB2 di port_b appaia lo stesso li¬ 
vello logico, per prima cosa dovrete andare nella 
finestra Watch, visibile in fig.77, per controllare l’in¬ 
dirizzo di port_a, che risulta essere CO (vedi sotto 
ADD). 



Fig.77 Finestra di Watch. 


Per forzare a livello logico 1 l’ingresso del piedi¬ 
no PA2 dovete andare nelle finestra DATA (vedi 
fig.78) poi ricercare nella colonna degli indirizzi di 
memoria il valore esadecimale CO. 

Trovato CO guardate nel righello in alto in cui ap¬ 
paiono i valori esadecimali: 

00-01-02-03-04-08-09-0A-0B-0C-0D-0E-0F 

Poiché l’indirizzo di port_a è CO, scendete dal va¬ 
lore esadecimale 00 fino ad incontrare la riga CO e 
così troverete il valore 00 (vedi fig.78). 

Portate il cursore su 00 e cliccate 2 volte. 



Fig.78 Cliccate 2 volte per vedere la fig.79. 





































Quando appare la finestra Edit Data (fig.79) do¬ 
vete cliccare sulla scritta Bits in modo da far ap¬ 
parire la finestra di fig.80. 



Fig.79 Scegliete Bits per vedere la fig.80. 
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ST6210 and ST6220. 



Fig.80 Qui potete forzare i livelli logici. 


In questa finestra potete vedere lo stato logico pre¬ 
sente su tutti i piedini della porta A e poiché tutte 
le caselle risultano vuote, è ovvio che su tutti i pie¬ 
dini è presente un livello logico 0. 

Volendo forzare a livello logico 1 il piedino d’in¬ 
gresso PA2 dovrete portare il cursore nella casel¬ 
la posta sotto il numero 2 e cliccare. 

Comparirà così V a conferma del fatto che sul pie¬ 
dino d’ingresso PA2 è ora presente un livello lo¬ 
gico 1. 

Nota: se cliccherete una seconda volta tornerà a 

livello logico 0. 

A questo punto cliccate su OK e nella finestra che 
appare ritornate a cliccare su OK: apparirà così la 
finestra di fig.81. 



Fig.81 Nel Watch vedrete il nuovo livello. 


Se ora guardate all’interno della finestra Watch ve¬ 
drete che qualcosa è cambiato, infatti sotto la co¬ 
lonna .Hex troverete 04 e sotto la colonna Dee. il 
numero 4. 


Poiché avevamo “bloccato” il programma pigiando 
Stop (icona con mano) per farlo ripartire dovete ri¬ 
cercare l’etichetta ripeti procedendo come segue: 

- Attivate la finestra Disassembler cliccando all’in¬ 
terno della finestra, quindi cliccate sulla scritta Di¬ 
sassembler del menu e poi cliccate sulla scritta 
Set New PC (vedi fig.82). 



- Apparirà così la finestra di dialogo New program 
counter (vedi fig.83) e cliccando sulla freccia po¬ 
sta a destra della finestra PC value dovrete ricer¬ 
care l’etichetta ripeti (vedi fig.84). 

Nota: tutte le etichette sono in ordine alfabetico. 



- Ponete il cursore su ripeti e cliccate, poi cliccate 
su OK e vedrete apparire la finestra di fig.85. 
Noterete che la prima riga in alto è ferma sull’eti¬ 
chetta ripeti. 








































































































- A questo punto posizionate il cursore sull’icona di 
esecuzione passo per passo e cliccate più volte 
fino ad arrivare all’istruzione: 

8DD 43 CO 07 jrr 2,port_a,main02 

Poiché questo bit è a livello logico 1, il program¬ 
ma non salterà più a main02 ma proseguirà all’i¬ 
struzione: 

8E0 53 CI 09 jrs 2,port_b,mains3 

Poiché PB2 è a livello logico 0 non salterà a 
mains3, ma, cliccando sul tasto passo per passo, 
proseguirà fino alla successiva istruzione che sarà: 

8E3 5B CI set 2,port_b 

Per eseguire questa istruzione cliccate ancora 
sull’icona passo passo ed il piedino PB2 cambierà 
il suo livello logico da 0 a 1. 

Per vedere se questa condizione si è verificata po¬ 
trete guardare nella finestra Watch dove leggere¬ 
te: 

port_b CI 04 4 

Se volete avere un’ulteriore conferma visiva anda¬ 
te nella finestra Data (fig.86), cercate l’indirizzo CO, 
poi andate sotto la colonna 01 e scendendo in¬ 
contrerete la casella 04. 

Portate il cursore su questa casella e cliccate due 

volte. 



00 01 02 03 04 OS 06 07 08 09 OÀ OB OC OD OE OF J 


90 - 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 . 

AO - 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 . | 

BO - 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 . 

CO - 04 GB 00 00 00 OF 00 00 00 00 00 00 00 OF 00 00 ..^j 



Fig.86 Sulla casella 04 cliccate 2 volte. 



Quando appare la maschera Edit Data (vedi fig.87) 
cliccate su Bits e comparirà la finestra di dialogo 
di fig.88 dove potrete vedere che nella casella sot¬ 
to il numero 2 del piedino PB2 c’è una V ad indi¬ 
care che questo piedino è a livello logico 1. 



Fig.87 Nell’Edit data cliccate su Bits. 



Per uscire cliccate su OK e nella successiva ma¬ 
schera cliccate nuovamente su OK: apparirà così 
la maschera di fig.85. 

Ora che avete vi abbiamo spiegato come sia pos¬ 
sa modificare un ingresso da livello logico 0 a li¬ 
vello logico 1 o viceversa, potete fare un po’ di 
pratica portando a livello logico 1 anche il piedi¬ 
no di un altro ingresso per poi riportarlo a livello 
logico 0, poi verificate se i piedini d’uscita sono 
passati da livello logico 0 a livello logico 1. 

Per verificarlo dovrete sempre far ripartire il pro¬ 
gramma dell’etichetta ripeti (vedi fig.85). 



NON ABBIAMO FINITO 


Con questo articolo abbiamo riportato solo una con¬ 
densata panoramica di quello che riesce a fare que¬ 
sto sofisticato software di simulazione. 

Per spiegarvi tutto, cioè insegnarvi a capire come 
scoprire gli errori, come correggerli ecc., dovre¬ 
mo portarvi tanti altri esempi, e per questo vi ri¬ 
mandiamo al prossimo numero. 

Comunque quando avrete a disposizione questo 
software, scoprirete voi stessi molte cose ed an¬ 
che facilmente tramite la funzione di Help. 

COSTO del dischetto SOFTWARE 

Tutti i softwaristi e hobbisti che volessero entrare 
in possesso di questo dischetto di simulazione per 
ST6 siglato DF622.03 potranno richiederlo alla no¬ 
stra Direzione. Costo del dischetto. € 7,75 













































































Prima di insegnarvi le procedure da adottare per 
cercare gli errori nei programmi scritti per i micro 
ST6, vi forniamo per ogni istruzione del linguaggio 
Assembler una tabella. 

Queste tabelle vi serviranno come guida rapida 
quando scriverete un programma o quando lo cor¬ 
reggerete, perché vi consentono di decifrare le co- 
difiche dell’opcode e degli indirizzi di memoria di 
ogni istruzione. 

Per avere una descrizione particolareggiata e cor¬ 
redata da esempi delle istruzioni in formato As¬ 
sembler vi consigliamo di rileggere quanto già pub¬ 
blicato sulla rivista N.174. 


In queste tabelle trovate il formato, l’opcode, i by- 
tes, i cicli e i flags di ogni istruzione. 


C = Carry, registro di stato. 

Z = Zero, registro di stato. 

dst = byte che contiene l’indirizzo di una variabi¬ 
le o di un registro il cui valore può essere modifi¬ 
cato dall’istruzione. 

e = 5 bits che esprimono un valore decimale com¬ 
posto da un numero da 0 a 63. 

ee = 8 bits che esprimono un valore decimale 
composto da un numero da 0 a 255. 

MSB = è l’abbreviazione di Most Significant Bit, 
cioè “bit significativo”. Si tratta del bit 7 che per 
la matematica binaria quando viene settato a 1 
vale in decimale 128 ed in binario 1000-0000. 


SOFTWARE simulatore per 


Formato = composizione di una istruzione. 
Opcode = codice operativo in formato intel.hex. 
Bytes = lunghezza dell’istruzione in bytes. 

Cicli = passi del micro per eseguire un’istruzione. 
Flags = particolari bit indicatori che vengono set¬ 
tati, cioè posti a livello logico 1 , oppure resetta¬ 
ti, cioè posti a livello logico 0, a seconda che si 
verifichino o meno determinate condizioni a segui¬ 
to dell’esecuzione di una istruzione. Questi bit in¬ 
dicatori vengono parcheggiati in speciali registri di 
stato chiamati Carry e Zero. 

Anche se conoscerete già il significato delle paro¬ 
le utilizzate nell’articolo, ne ricordiamo qui alcune: 

Variabile = è l’indirizzo di memoria Data Space i- 
dentificato da un nome, ad esempio port_a, con¬ 
tenente un valore che nel corso dell’elaborazione 
può variare. 


PC = Program Counter. E’ un registro a 12 bit con¬ 
tenente l’indirizzo dell’istruzione in esecuzione. 

sre = byte che contiene l’indirizzo di una variabi¬ 
le o di un registro il cui valore non è modificabile 
dall’istruzione. 

In ogni Tabella troverete il significato delle abbre¬ 
viazioni utilizzate che qui non compaiono, e le o- 
perazioni che effettua il programma quando ese¬ 
gue l’istruzione. 

Per capire come usare queste Tabelle di guida ra¬ 
pida prendiamo ad esempio quella dell’istruzione 

Set. 

Una volta che avrete letto la spiegazione, saprete 
anche come usare tutte le altre tabelle. 


SET Set Bit 


Overflow = letteralmente significa “traboccamen¬ 
to”. Questo evento si verifica se il risultato di un’o¬ 
perazione matematica ci fornisce un valore più 
grande della capacità della variabile in cui lo do¬ 
vremmo memorizzare. Ad esempio, se il risultato 
di una somma è 300 e tentate di memorizzare que¬ 
sto numero in una variabile lunga 1 byte che può 
contenere un valore compreso tra 0 e 255, si veri¬ 
ficherà un overflow. 

Le abbreviazioni che troverete utilizzate in quasi 
tutte le istruzioni hanno il seguente significato. 


Formato 

opcode 

bytes 

cicli 

flags 

SET bit,dst 




Z 

c 

SET b,A 

bl1011 FF 

2 

4 

* 

* 

SET b,rr 

bl 1011 rr 

2 

4 

* 

* 


Operazione: istruzione che serve per settare uno 
degli 8 bit della Variabile dst. 

A = registro dell’Accumulatore, 
b = numero binario di tre bit di indirizzo, 
rr = 1 byte di indirizzo di una Variabile. 

* = Z - C non influenzati. 
















Come vi abbiamo promesso nella rivista precedente, in questo articolo prose¬ 
guiamo a spiegarvi come usare il “software simulatore DSE622” dandovi alcu¬ 
ni utili suggerimenti sui diversi test che è possibile eseguire sui programmi scrit¬ 
ti in linguaggio Assembler. Anche i più esperti infatti possono involontariamente 
commettere errori nel programmare i microprocessori della famiglia ST6. 


Nella colonna Formato abbiamo riportato il forma¬ 
to logico dell’Istruzione. 

L’istruzione Set si compone di un comando (Set), 
del bit da settare (bit) e della variabile (dst) in cui 
verrà settato (livello logico 1) il bit. 

Esempio di - SET b,A 

Per settare un bit dell’accumulatore A dobbiamo 
guardare la colonna opcode, in cui viene riportata 
la sua configurazione in formato intel.hex. 

blIOI1 FF 

b = è la combinazione di tre bit utilizzati per defi¬ 
nire in binario un numero decimale da 0 a 7. 

11011 = è la combinazione binaria che il micro- 
processore riconosce come l’istruzione Set, quindi 
non deve essere mai modificata. 

b+11011 = è dunque un numero binario di 8 bit 
che il computer utilizza per sapere quale bit dell’ac¬ 
cumulatore A deve settare. Questo numero bina¬ 
rio occupa 1 byte. 


FF = è l’indirizzo di memoria dell’accumulatore A 
in formato esadecimale. Questo indirizzo è di 1 by¬ 
te. 

Tutta l’istruzione blIOIIFF occupa un totale di 2 
byte, come potete vedere nella terza colonna de¬ 
nominata bytes. 

Nella quarta colonna (ciclo) sono riportati i nume¬ 
ri di passi necessari al microprocessore per ese¬ 
guire l’istruzione. 

Ammesso di avere un quarzo da 8 MHz, per co¬ 
noscere il tempo di esecuzione espresso in mi¬ 
crosecondi possiamo usare questa formula: 

microsecondi = (13 : MHz) x cicli macchina 

Questa istruzione verrà perciò eseguita in: 

(13 : 8) x 4 = 6,5 microsecondi 

Nella quinta colonna (Flags Z - C) trovate degli a- 
sterischi perché l’istruzione set non influenza lo sta¬ 
to logico di Z e di C. 






Esempio: Per settare il bit 7 dell’Accumulatore 

dobbiamo scrivere questa istruzione: 

set 7,A 

Il compilatore Assembler convertirà l’istruzione in 
questi numeri binari: 

11111011 11111111 

Nel numero binario 11111011 (esadecimale FB) i 
primi cinque bit partendo da destra, cioè 11011, 
corrispondono all’istruzione Set. 

Gli ultimi tre bit, cioè 111, corrispondono al numero 
decimale 7. 

Il secondo numero binario, cioè limili (esa¬ 
decimale FF), corrisponde al numero dell’indirizzo 

dell’Accumulatore. 

Tutta l’istruzione viene visualizzata sul monitor dal 
simulatore non in numero binario, ma in un nu¬ 
mero esadecimale, cioè: 

FB FF 

Esempio di - SET b,rr 

Per settare un bit della Variabile rr dobbiamo guar¬ 
dare la colonna opcode, in cui viene riportata la 
sua configurazione in formato intel.hex. 

blIOII rr 

b = è la combinazione di tre bit utilizzati per defi¬ 
nire in binario un numero decimale da 0 a 7. 

11011 = è la combinazione binaria che il micro- 
processore riconosce come l’istruzione Set, quindi 
non deve essere mai modificata. 

b+11011 = è dunque un numero binario di 8 bit 
che il computer utilizza per sapere quale bit della 
variabile rr deve settare. Questo numero binario 
occupa 1 byte. 

rr = è l’indirizzo di memoria della Variabile di Da¬ 
ta Space. Questo indirizzo è di 1 byte. 

Tutta l’istruzione bl 1011 rr occupa un totale di 2 
byte, come potete vedere nella terza colonna de¬ 
nominata bytes. 

Nella quarta colonna (ciclo) sono riportati i nume¬ 
ri di passi necessari al microprocessore per ese¬ 
guire l’istruzione. 

Nella quinta colonna (Flags Z - C) trovate degli a¬ 


sterischi perché l’istruzione set non influenza lo sta¬ 
to logico di Z e di C. 

Esempio: Per settare il bit 2 di port_a, cioè per 
portare a livello logico 1 il piedino PA2 della por¬ 
ta A, dobbiamo scrivere questa istruzione: 

set 2,port_a 

Il compilatore Assembler convertirà l’istruzione in 
questi numeri binari: 

01011011 11000000 

Nel numero binario 01011011 (esadecimale 5B) i 
primi cinque bit partendo da destra, cioè 11011, 
corrispondono all’istruzione Set. 

Gli ultimi tre bit, cioè 010, corrispondono al numero 
decimale 2. 

Il secondo numero binario, cioè 11000000 (esade¬ 
cimale CO), corrisponde all’indirizzo di port_a. 

Tutta l’istruzione viene visualizzata sul monitor dal 
simulatore non in numero binario, ma in un nu¬ 
mero esadecimale, cioè : 

5B CO 

Di seguito trovate tutte le Tabelle della guida ra¬ 
pida in ordine alfabetico. 


ADD Addition 


Formato 

opcode 

bytes 

cicli 

flags 

ADD dst,src 


Z 

C 

ADD A,A 

5F FF 

2 

4 

A 

A 

ADD A,X 

5F 80 

2 

4 

A 

A 

ADD A,Y 

5F 81 

2 

4 

A 

A 

ADD A,V 

5F 82 

2 

4 

A 

A 

ADD A,W 

5F 83 

2 

4 

A 

A 

ADD A,(X) 

47 

1 

4 

A 

A 

ADD A,(Y) 

4F 

1 

4 

A 

A 

ADD A,rr 

5F rr 

2 

4 

A 

A 


Operazione: il contenuto di una variabile viene 
sommato al contenuto dell’Accumulatore ed il ri¬ 
sultato dell’operazione è memorizzato nell’Accu¬ 
mulatore. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è resettato prima dell’operazione e si setta 
automaticamente se l’addizione genera overflow. 























ADDI Addition Immediate 


CALL Cali Subroutine 


Formato 

opcode 

bytes 

cicli 

flags 

ADDI dst,src 




Z 

c 

ADDI A,nn 

57 nn 

2 

4 

A 

A 


Formato 

opcode 

bytes 

cicli 

CALL dst 




CALL abc 

c0001 ab 

2 

4 



Operazione: un numero viene sommato al conte¬ 
nuto dell’Accumulatore ed il risultato dell’opera¬ 
zione è memorizzato nell’Accumulatore. 

A = registro dell’Accumulatore, 
nn = numero di 1 byte (da 0 a 255). 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è resettato prima dell’operazione e si setta 
automaticamente se l’addizione genera overflow. 


Operazione: viene utilizzata per chiamare una su¬ 
broutine. Ogni volta che viene eseguita una Cali 
il Program Counter viene memorizzato nel livello 
corrente di Stack e quest’ultimo si alza di un livel¬ 
lo. Nel micro ST62 il numero massimo dei livelli di 
Stack è 6. 

abc = etichetta della subroutine da eseguire e- 
spressa in 3 semibytes per un totale di 12 bit. 

* = Z - C non influenzati. 


AND Logicai AND 


CLR Clear 


Formato 

opcode 

bytes 

cicli 

flags 

AND dst,sre 


Z 

c 

AND A,A 

BF FF 

2 

4 

A 

* 

AND A,X 

BF 80 

2 

4 

A 

* 

AND A,Y 

BF 81 

2 

4 

A 

* 

AND A,V 

BF 82 

2 

4 

A 

* 

AND A,W 

BF 83 

2 

4 

A 

* 

AND A,(X) 

A7 

1 

4 

A 

* 

AND A,(Y) 

AF 

1 

4 

A 

* 

AND A,rr 

BF rr 

2 

4 

A 

* 


Operazione: funzione di And tra l’Accumulatore 
ed una Variabile. Il risultato della funzione è me¬ 
morizzato nell’Accumulatore. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = C non influenzato. 



Operazione: serve per resettare l’Accumulatore, 
un Registro o una Variabile. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato. 

A = C è resettato. 

* = Z - C non influenzati. 

COM Complement 


ANDI LOGICAL AND Immediate 


Formato 

opcode 

bytes 

cicli 

flags 

ANDI dst,sre 




Z C 

ANDI A,nn 

B7 nn 

2 

4 

A 


Operazione: viene eseguita la funzione di And di 
un numero con l’Accumulatore. Il risultato della 
funzione è memorizzata nell’Accumulatore. 


Formato 

opcode 

bytes 

cicli 

COM dst 




COM A 

2D 

1 

4 



Operazione: calcola il complemento al valore con¬ 
tenuto nell’Accumulatore e lo memorizza nell’Ac¬ 
cumulatore stesso. A questo scopo utilizza la fun¬ 
zione di Not che inverte i livelli logici contenuti 
nell’Accumulatore. 


A = registro dell’Accumulatore, 
nn = numero di 1 byte (da 0 a 255). 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = C non influenzato. 


A = registro dell’Accumulatore. 

A = Z è settato se il risultato della funzione è 0, re¬ 
settato se diverso da 0. 

A = C è settato se prima della funzione il bit 7 è 
1, resettato se prima della funzione il bit 7 è 0. 



















































CP Compare 


Formato 

opcode 

bytes 

cicli 

flags 

CP dst,src 



Z 

C 

CP A,A 

3F FF 

2 

4 

A 

A 

CP A,X 

3F 80 

2 

4 

A 

A 

CP A,Y 

3F 81 

2 

4 

A 

A 

CP A,V 

3F 82 

2 

4 

A 

A 

CP A,W 

3F 83 

2 

4 

A 

A 

CP A,(X) 

27 

1 

4 

A 

A 

CP A,(Y) 

2F 

1 

4 

A 

A 

CP A,rr 

3F rr 

2 

4 

A 

A 


Operazione: compara il contenuto di un Registro 
o di una Variabile con il contenuto dell’Accumu¬ 
latore, sottraendo dal contenuto dell’Accumulato¬ 
re il contenuto della Variabile o del Registro. L’Ac¬ 
cumulatore rimane invariato. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è settato se l’Accumulatore è minore del 
contenuto del Registro o della Variabile, è reset¬ 
tato se l’Accumulatore è uguale o maggiore. 


CPI Compare Immediate 


Formato 

opcode 

bytes 

cicli 

flags 

CPI dst,src 




Z 

C 

CPI A,nn 

37 nn 

2 

4 

A 

A 


Operazione: compara il contenuto dell’Accumula¬ 
tore con un numero contenuto in un byte, sot¬ 
traendo dal contenuto dell’Accumulatore il numero. 
L’Accumulatore rimane invariato. 

A = registro dell’Accumulatore. 

nn = numero di 1 byte (da 0 a 255). 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è settato se l’Accumulatore è minore del 
numero nn, è resettato se l’Accumulatore è u- 
guale o maggiore. 

DEC Decrement 


Formato 

opcode 

bytes 

cicli 

flags 

DEC dst 


Z 

C 

DEC A 

FF FF 

2 

4 

A 

* 

DEC X 

1D 

1 

4 

A 

* 

DEC Y 

5D 

1 

4 

A 

* 

DEC V 

9D 

1 

4 

A 

* 

DEC W 

DD 

1 

4 

A 

* 

DEC (X) 

E7 

1 

4 

A 

* 

DEC (Y) 

EF 

1 

4 

A 

* 

DEC rr 

FF rr 

2 

4 

A 

* 


Operazione: decrementa di 1 il contenuto dell’Ac¬ 
cumulatore, del Registro o della Variabile. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = C non viene in alcun modo influenzato, quindi 
mantiene lo stesso stato, livello logico 0 o livello lo¬ 
gico 1, in cui si trovava prima dell’istruzione. 


INC Increment 


Formato 

opcode 

bytes 

cicli 

flags 

INC dst 


Z 

C 

INC A 

7F FF 

2 

4 

A 

* 

INC X 

15 

1 

4 

A 

* 

INC Y 

55 

1 

4 

A 

* 

INC V 

95 

1 

4 

A 

* 

INC W 

D5 

1 

4 

A 

* 

INC (X) 

67 

1 

4 

A 

* 

INC (Y) 

6F 

1 

4 

A 

* 

INC rr 

7F rr 

2 

4 

A 

* 


Operazione: incrementa di 1 il contenuto dell’Ac¬ 
cumulatore, del Registro o della Variabile. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = C non viene in alcun modo influenzato, quin¬ 
di mantiene lo stesso stato, livello logico 0 o li¬ 
vello logico 1, in cui si trovava prima dell’istruzio¬ 
ne. 


JP Jump 


Formato 

opcode 

bytes 

cicli 

flags 

JP dst 




Z 

C 

JP abc 

clOOl ab 

2 

4 

* 

* 


Operazione: viene utilizzata per fare un salto in¬ 
condizionato ad una etichetta. 

abc = indirizzo di Program Space dell’etichet¬ 
ta. Nel Program Space viene memorizzato que¬ 
sto indirizzo ed il programma “salta” all’etichet¬ 
ta per poi proseguire da questo punto in poi. 
abc è espresso in 3 semibytes per un totale di 
12 bit. 

* = Z e C non influenzati. 











































































JRC Jump Relative on Carry Flag 


JRR Jump Relative if Reset 


Formato opcode bytes cicli flags 

zie 


| JRC e | elio | 1 | 2 | * | * I 

Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal Carry Flag quando questo è setta¬ 
to. 


Formato opcode bytes cicli flags 

Z | C 


|jRRb,rr,ee | bOOOII rree| 3 | 5 | * | A 1 

Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal bit di una Variabile quando questo 
è resettato. 


e = numero che rappresenta la distanza di byte 
dell’etichetta di salto rispetto al Program Counter. 
Il numero possibile di bytes di salto è 15 prima e 
16 dopo rispetto al Program Counter. 

* = Z e C non vengono in alcun modo influenzati, 
quindi mantengono lo stesso stato, livello logico 0 
o livello logico 1, in cui si trovavano prima dell’i¬ 
struzione. 


JRNC Jump Relative on Non Carry Flag 



Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal Carry Flag quando questo è reset¬ 
tato. 

e = numero che rappresenta la distanza di byte 
dell’etichetta di salto rispetto al Program Counter. 
Il numero possibile di bytes di salto è 15 prima e 
16 dopo rispetto al Program Counter. 

* = Z e C non vengono in alcun modo influenzati, 
quindi mantengono lo stesso stato, livello logico 0 
o livello logico 1, in cui si trovavano prima dell’i¬ 
struzione. 


JRNZ Jump Relative on Non Zero Flag 


bytes cicli 

I z I c 


JRNZ e eOOO 12 


Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal Zero Flag quando questo è reset¬ 
tato. 

e = numero che rappresenta la distanza di by¬ 
te dell’etichetta di salto rispetto al Program 
Counter. Il numero possibile di bytes di salto è 
15 prima e 16 dopo rispetto al Program Coun¬ 
ter. 

* = Z e C non influenzati. 


b = numero binario di tre bit di indirizzo, 
rr = 1 byte di indirizzo di una Variabile, 
ee = numero che rappresenta la distanza di byte 
dell’etichetta di salto rispetto al Program Counter. 
Il numero possibile di bytes di salto è 126 prima 
e 129 dopo rispetto al Program Counter. 

* = Z non viene in alcun modo influenzato, quindi 
mantiene lo stesso stato, livello logico 0 o livello lo¬ 
gico 1, in cui si trovava prima dell’istruzione. 

A = C contiene il valore del bit testato. 

JRS Jump Relative if Set 



Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal bit di una Variabile quando questo 
è settato. 

b = numero binario di tre bit di indirizzo, 
rr = 1 byte di indirizzo di una Variabile, 
ee = numero che rappresenta la distanza di byte 
dell’etichetta di salto rispetto al Program Counter. 
Il numero possibile di bytes di salto è 126 prima 
e 129 dopo rispetto al Program Counter. 

* = Z non viene in alcun modo influenzato, quindi 
mantiene lo stesso stato, livello logico 0 o livello lo¬ 
gico 1, in cui si trovava prima dell’istruzione. 

A = C contiene il valore del bit testato. 

JRZ Jump Relative on Zero Flag 



Operazione: viene utilizzata per fare un salto con¬ 
dizionato dal Zero Flag quando questo è settato. 

e = numero che rappresenta la distanza di byte 
dell’etichetta di salto rispetto al Program Counter. 
Il numero possibile di bytes di salto è 15 prima e 
16 dopo rispetto al Program Counter. 

* = Z e C non influenzati. 


Formato opcode 


flags 






































LD Load 


NOP No Operation 


Formato 

opcode 

bytes 

cicli 

flags 

LD dst,src 


Z 

c 

LD A,X 

35 

1 

4 

A 

* 

LD A,Y 

75 

1 

4 

A 

* 

LD A,V 

B5 

1 

4 

A 

* 

LD A,W 

F5 

1 

4 

A 

* 

LD X,A 

3D 

1 

4 

A 

* 

LD Y,A 

7D 

1 

4 

A 

* 

LD V,A 

BD 

1 

4 

A 

* 

LD W,A 

FD 

1 

4 

A 

* 

LD A,(X) 

07 

1 

4 

A 

* 

LD (X),A 

87 

1 

4 

A 

* 

LD A,(Y) 

0F 

1 

4 

A 

* 

LD (Y),A 

8F 

1 

4 

A 

* 

LD A,rr 

1F rr 

2 

4 

A 

* 

LD rr,A 

9F rr 

2 

4 

A 

* 


Operazione: serve per caricare il valore contenu¬ 
to in una Variabile, nell’Accumulatore o in un Re¬ 
gistro. Può caricare il valore anche tra Registro 
ed Accumulatore Per questa istruzione bisogna 
sempre utilizzare l’Accumulatore. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = C non viene in alcun modo influenzato, quindi 
mantiene lo stesso stato, livello logico 0 o livello lo¬ 
gico 1, che aveva prima dell’istruzione. 

LDI Load Immediate 


Formato 

opcode 

bytes 

cicli 

flags 

LDI dst,src 




Z 

c 

LDI A,nn 

17 nn 

2 

4 

A 

* 

LDI X,nn 

OD 80 nn 

3 

4 

* 

* 

LDI Y,nn 

OD 81 nn 

3 

4 

* 

* 

LDI V,nn 

OD 82 nn 

3 

4 

* 

* 

LDI W,nn 

OD 83 nn 

3 

4 

* 

* 

LDI rr,nn 

OD rr nn 

3 

4 

* 

* 


Operazione: serve per caricare un numero da 0 a 

255 in una Variabile, nell’Accumulatore o in un 
Registro. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 
nn = numero di 1 byte (da 0 a 255). 
rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

* = Z - C non influenzati. 


Formato 

opcode 

bytes 

cicli 





NOP 

04 

1 

2 



Operazione: viene normalmente utilizzata per 
creare dei piccoli ritardi. Ogni NOP crea un ritar¬ 
do di 2 cicli. 


= Z - C non influenzati. 

RES Reset Bit 


Formato 

opcode 

bytes 

cicli 

flags 

RES bit, dst 




Z 

c 

RES b,A 

bOI011 FF 

2 

4 

* 

* 

RES b,rr 

bOI 011 rr 

2 

4 

* 

* 


Operazione: serve per resettare uno degli 8 bit 
della Variabile o dell’Accumulatore di destinazio¬ 
ne. 

A = registro dell’Accumulatore 
b = numero binario di tre bit di indirizzo, 
rr = 1 byte di indirizzo di una Variabile. 

* = Z - C non influenzati. 

RET Return from Subroutine 


Formato 

I opcode 

bytes 

cicli 

flags 


mm 

mm 

Z C 

RET 

CD 



* * 


Operazione: viene utilizzata per ritornare da una 
subroutine al punto della chiamata Cali. Quando 
viene eseguita una RET si abbassa di un livello lo 
Stack ed il Program Counter assume il valore re¬ 
lativo al livello corrente di Stack. 

* = Z e C non influenzati. 

RETI Return from Interrupt 


Formato 

opcode 

bytes 

cicli 

flags 



mm 

mm 

N 

o 




S 

A A 


Operazione: viene utilizzata per ritornare da una 
routine di interrupt al punto precedente all’evento 
di interrupt. Quando viene eseguita una RETI si ab¬ 
bassa di un livello lo Stack ed il Program Counter 
assume il valore relativo al livello corrente di Stack. 

A = Z e C vengono riportati alla condizione logica 
in cui si trovavano prima dell’interrupt. 




















































































RLC Rotate Left Through Carry 


SUB Subtraction 



Operazione: serve per spostare di un posto verso 

sinistra gli 8 bit dell’Accumulatore. Il bit 7 passa 
nel Carry spostando il valore che si trovava sul 
Carry sul bit 0 dell’Accumulatore. 

A = registro dell’Accumulatore. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C riporta il valore del bit 7. 


SET Set Bit 


Formato 

opcode 

bytes 

cicli 

flags 

SET bit,dst 




Z 

c 

SET b,A 

blIOII FF 

2 

4 

* 

* 

SET b,rr 

bl 1011 rr 

2 

4 

* 

* 


Operazione: serve per settare uno degli 8 bit del¬ 
la Variabile o dell’Accumulatore di destinazione. 


A = registro dell’Accumulatore 
b = numero binario di tre bit di indirizzo, 
rr = 1 byte di indirizzo di una Variabile. 

* = Z - C non influenzati. 

SLA Shift Left Accumulator 



Operazione: serve per spostare di un posto verso 
sinistra gli 8 bit dell’Accumulatore. Il bit 7 passa 
nel Carry cancellando il valore che risultava pre¬ 
sente (equivale ad una moltiplicazione per 2). 

A = registro dell’Accumulatore. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C riporta il valore del bit 7. 


STOP Stop Operation 


Formato 

opcode 

bytes 

cicli 

flags 





Z 

c 

STOP 

6D 

1 

2 

* 

a 


Operazione: serve per bloccare l’oscillatore del 
clock mettendo in stand-by tutto il micro ST62. 


Formato 

opcode 

bytes 

cicli 

flags 

SUB dst,src 


Z 

C 

SUB A,A 

DF FF 

2 

4 

A 

A 

SUB A,X 

DF 80 

2 

4 

A 

A 

SUB A,Y 

DF 81 

2 

4 

A 

A 

SUB A,V 

DF 82 

2 

4 

A 

A 

SUB A,W 

DF 83 

2 

4 

A 

A 

SUB A,(X) 

C7 

1 

4 

A 

A 

SUB A,(Y) 

CF 

1 

4 

A 

A 

SUB A,rr 

DF rr 

2 

4 

A 

A 


Operazione: il contenuto di una variabile viene 
sottratto all’Accumulatore ed il risultato dell’o¬ 
perazione viene memorizzato nell’Accumulato¬ 
re. 

A = registro dell’Accumulatore. 

X-Y-V-W = registri del micro. 

rr = 1 byte di indirizzo di una Variabile. 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è settato se il contenuto dell’Accumulato¬ 
re è minore della Variabile o del Registro, reset¬ 
tato se maggiore o uguale. 

SUBÌ Subtraction Immediate 


Formato 

opcode 

bytes 

cicli 

flags 

SUBÌ dst,src 




Z 

C 

SUBÌ A,nn 

D7 nn 

2 

4 

A 

LAJ 


Operazione: un numero contenuto in un byte 

viene sottratto all’Accumulatore ed il risultato 
dell’operazione viene memorizzato nell’Accumu¬ 
latore. 

A = registro dell’Accumulatore. 

nn = numero di 1 byte (.da 0 a 255). 

A = Z è settato se il risultato è 0, resettato se di¬ 
verso da 0. 

A = C è settato se il contenuto dell’Accumulatore 
è minore del numero, resettato se maggiore o u- 
guale. 


WAIT Wait Processor 


Formato 

opcode 

bytes 

cicli 

flags 





Z 

c 

WAIT 

ED 

1 

2 

* 

a 


Operazione: serve per mettere in stand-by il mi¬ 
cro ST62, ma l’oscillatore del clock rimane atti¬ 
vo. 


* = Z - C non influenzati. 


= Z - C non influenzati. 



































































Chi, subito dopo aver letto l’articolo apparso sulla 
rivista N.184, si è affrettato ad acquistare il di¬ 
schetto con il software DSE.622, che serve a “te¬ 
stare” tutti i programmi per i micro ST6, si è subi¬ 
to accorto con quanta facilità sia possibile simula¬ 
re i programmi in Assembler. 

Questo software consente di individuare dove e 
perché il programma non funziona e di correggere 
gli errore logici, facendo risparmiare così non so¬ 
lo tempo ma anche denaro, perché non è più ne¬ 
cessario acquistare gli ST6 riprogrammabili per 
provare i programmi. 

Abbiamo ricevuto molte lettere di elogio soprattut¬ 
to dagli uffici tecnici delle piccole e medie Indu¬ 
strie che usano gli ST6 per le loro macchine, e mol¬ 
ti Professori che insegnano negli Istituti Tecnici 
ci hanno fatto sapere che lo considerano un valido 
supporto didattico alle loro lezioni teoriche. 

In realtà questi complimenti non sono molto meri¬ 
tati perché noi ci siamo soltanto limitati a cercare 
tra i tanti software disponibili in commercio quello 
che ci sembrava il più valido come hardware e 
software e, quando l’abbiamo trovato, abbiamo 
spiegato sulla rivista in modo molto semplice e con 
tanti esempi il suo funzionamento e l’utilità delle 
sue funzioni più importanti. 

Prima di spiegarvi come cercare e correggere gli 
errori che si possono commettere quando si scrive 
un programma, vogliamo aprire una parentesi per 
insegnarvi a generare il file .SYM. 


SE NON APPARE IL FILE .SYM 


Nella rivista N.184 vi abbiamo detto che il file *.PRJ 
utilizzato dal simulatore per testare il programma è 
formato: 

- dal file .HEX, che contiene il programma esegui¬ 
bile in formato INTEL.HEX. 

- dal file .SYM, che contiene le definizioni delle e- 
tichette ed il relativo indirizzo di memoria Program 
Space. 

- dal file .DSD, che contiene le definizioni, le ca¬ 
ratteristiche ed il relativo indirizzo di memoria Da¬ 
ta Space delle variabili. 

- dalle specifiche proprie che vengono scelte da 
chi crea il file .PRJ dal file .HEX. 

Molti lettori ci hanno segnalato che quando compi¬ 
lano in assembler non riescono a vedere il conte¬ 
nuto del file .SYM, quindi sul video non compare la 
parte del programma relativa alle etichette in for¬ 
mato simbolico, ma solo il loro indirizzo di memo¬ 
ria (vedi fig.90). 


Per questo motivo quando avete assemblato il file 
ATEST.ASM per generare il file ATEST.PRJ, so¬ 
no stati creati solo i files: 

ATEST.HEX 

ATEST.DSD 

e non il file: ATEST.SYM 


Anche se questo file non viene creato, il simulato¬ 
re svolge ugualmente tutte le sue funzioni, ma in¬ 
vece di mostrarvi nel DSE le etichette in formato 
simbolico, fornisce solo la loro codifica in esade- 
cimale. 


Dal momento che invece è molto più semplice in 
fase di simulazione lavorare con il formato .SYM, 
vi spieghiamo come generarlo. 


Come prima operazione caricate il programma 
DSE622 e quando compare la finestra di fig.91, se¬ 
lezionate la scritta Demo per entrare nella finestra 
principale. 

Cliccate sulla scritta Tools sulla barra dei menu e 
selezionate ST6 (vedi fig.92). 



Fig.90 Se in fase di compilazione non è sta¬ 
to creato il file *.SYM, nel file .PRJ le eti¬ 
chette sono codificate in esadecimale. 



Fig.91 Scegliete l’opzione Demo per entra¬ 
re nella finestra principale del DSE622. 



Fig.92 Per entrare nell’editor dell’ST6 dal D- 
SE, scegliete ST6 dal menu Tools. 




























































In questo modo entrerete nell’editor dell’ST6. 

Per aprire il file usate il tasto F3 e, nella riga Na- 
me, digitate *.BAT come visibile nella fig.93. 
Cliccate su Open e vedrete apparire la finestra ri¬ 
portata in fig.94, dove risulta già selezionato il file 
A.BAT. 

Cliccate su Open e sul monitor apparirà il conte¬ 
nuto di questo file, cioè ast6 %1. 

Per generare il file .SYM, è necessario inserire in 
questa riga l’opzione -S. 

Per aggiungere questa opzione dovete portare il 
cursore dopo la scritta ast6, digitare uno spazio e 
scrivere -s, quindi separare con uno spazio la scrit¬ 
ta 1 %. 

In altre parole deve apparire: 

ast6 -s %1 

come visibile nella finestra di fig.95. 

A questo punto salvate il file premendo il tasto 
funzione F2, poi uscite premendo i due tasti 

Alt+F3. 

Per completare la modifica dovete nuovamente 
compilare i files: 

ATEST.ASM 

BTEST.ASM 

Per compilare il file ATEST.ASM pigiate il tasto 
funzione F3, poi selezionate il programma 
ATEST.ASM, quindi portate il cursore su Open e 
cliccate. 

Nella finestra che appare (vedi fig.96) cliccate sul¬ 
la scritta ST6 poi su Assembla. 

Quando il programma sarà compilato premete un 
tasto qualsiasi, poi premete Alt+F3 per chiudere 
il file. 

La stessa operazione deve essere effettuata per il 
file BTEST.ASM e per tutti quei files che avete 
compilato prima di aggiungere l’opzione -S al file 

A.BAT. 

Terminata questa operazione potete uscire dall’e- 
ditor premendo i tasti Alt+X. 

Rientrerete così nel software di simulazione del 
DSE622 dove tutti i files con estensione .PRJ che 
avete generato prima di questa modifica sono sta¬ 
ti automaticamente aggiornati e contengono quin¬ 
di anche le informazioni in formato simbolico rela¬ 
tive al file .SYM. 



Fig. 93 Utilizzate il tasto funzione F3 per a- 
prire il file con estensione .BAT. 



Fig.94 II file che dovete modificare per ge¬ 
nerare il file .SYM si chiama A.BAT. 
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Fig.95 L’opzione -s, che serve a generare il 
file .SYM in fase di compilazione, deve es¬ 
sere inserita tra le scritte ast6 e 1% sepa¬ 
randola con degli spazi. 



Fig.96 Tutti i files che avete compilato pri¬ 
ma di aggiungere l’opzione -s devono es¬ 
sere nuovamente assemblati. 







































LA CORREZIONE DEGLI ERRORI 

Dopo questa parentesi riprendiamo la descrizione 
del funzionamento del DSE fornendovi alcuni sug¬ 
gerimenti per controllare passo-passo le istruzio¬ 
ni e di conseguenza correggere gli errori che si 
possono commettere quando si scrive un pro¬ 
gramma. 

Per correggere un errore possiamo optare tra due 
soluzioni: 

- correggere in maniera temporanea il file .PRJ 

- correggere in maniera definitiva il file .ASM 

Le correzioni temporanee riguardano il solo file 
.PRJ, quindi spegnendo il computer o comunque 
uscendo dal programma DSE622 vengono tutte 
perdute. 

Le correzioni definitive possono essere portate so¬ 
lo sul file .ASM, ma spegnendo il computer o u- 
scendo dal programma rimangono in memoria. 

Leggendo quanto sopra sembrerebbe più logico fa¬ 
re le correzioni direttamente nel sorgente, cioè nel 
file con estensione .ASM, ma non sempre convie¬ 
ne andare in questa direzione per i seguenti sem¬ 
plici motivi: 

- potrebbero esserci altri errori oltre a quello che 
avete corretto, 

- potreste inserirne uno proprio durante la corre¬ 
zione. 

Inoltre per ricontrollare il programma dovreste nuo¬ 
vamente compilare il file .ASM, creare il file .PRJ 
e settare daccapo i piedini per effettuare una cor¬ 
retta simulazione. 

E’ quindi consigliabile apportare, dove possibile, le 
correzioni in modo temporaneo sul file .PRJ, poi 
simulare l’esecuzione del programma e, una volta 
verificato che tutto funziona regolarmente, potrete 
correggere definitivamente il sorgente. 

Tuttavia non tutte le correzioni si possono appor¬ 
tare nel file .PRJ. 

Ad esempio non si può sostituire un’istruzione lun¬ 
ga 2 bytes con una lunga 3 bytes, perché il byte 
in eccesso andrebbe a ricoprire il primo byte dell’i¬ 
struzione successiva sconvolgendo compieta- 
mente le funzioni del programma. 

Quindi prima di sostituire un’istruzione con un’altra 
bisogna sempre controllare che la nuova istruzio¬ 
ne non risulti più lunga di quella da sostituire. 

Ad esempio l’istruzione JRZ (che è lunga 1 byte) 


non può essere sostituita dall’istruzione JRR (che 
è lunga 3 bytes), ma si può invece fare il contra¬ 
rio utilizzando l’istruzione NOP per coprire i bytes 
non utilizzati. 

Esempio: Ammesso di voler modificare l’istruzio¬ 
ne: 

jrr 0,potr_b,mains1 ^istruzione lunga 3 byte) 
con l’istruzione: 

jrz mainsl ^istruzione lunga 1 byte) 

poiché mancano 2 bytes dovremo aggiungere due 
istruzioni Nop per avere di nuovo 3 bytes: 

jrz mainsl nop nop 

Ad ogni modo ricordatevi di non eccedere con i 
NOP perché occupereste solo della memoria per 
eseguire istruzioni a vuoto. 

Quindi se questo vi accadesse vi converrà correg¬ 
gere e rivedere tutto il programma direttamente nel 
sorgente. 

Per conoscere la lunghezza in byte di tutte le i- 
struzioni potete consultare le tabelle della guida 
pratica che trovate all’inizio dell’articolo. 

GLI errori nel programma BTEST 

Come vi abbiamo spiegato nella rivista N.184, nel 
programma BTEST.ASM abbiamo inserito degli er¬ 
rori, per la precisione tre, al fine di mostrarvi co¬ 
me procedere per poterli individuare e di conse¬ 
guenza correggere. 

La tipologia degli errori che vi proponiamo con 
questo esempio pratico ci permette di spiegarvi 
quali test vanno eseguiti e come vanno eseguiti 
per trovare gli errori. 

Inoltre vi spiegheremo come apportare le modifi¬ 
che temporanee e definitive in qualsiasi program¬ 
ma in linguaggio Assembler per micro ST6. 

Per simulare il programma BTEST è prima neces¬ 
sario che lo compiliate in Assembler, in modo da 
creare il file BTEST.HEX, e che generiate il rispet¬ 
tivo project, cioè il file BTEST.PRJ, che viene uti¬ 
lizzato dal simulatore per testare il programma. 

Per eseguire tutte queste operazioni rimandiamo a 
quanto già ampiamente descritto nel paragrafo 
“Compilare in assembler il programma atest.asm" 
riportate a pag.112 e seguenti della rivista N.184. 

Quando appare la finestra di fig.97, aprite il file se¬ 
lezionando dal menu Project, in alto a sinistra sul¬ 
la barra del menu, il comando Open Project. 


Si aprirà così la finestra di dialogo File Open visi¬ 
bile in fig.98. 

Nella finestra a sinistra selezionate la scritta 
BTEST.PRJ quindi cliccate su OK. 

A video compariranno tutte le finestre visibili in 
fig.99, che vi consentono di controllare istruzione 
per istruzione il programma. 



Prima di testare il programma dovete inserire le 
variabili della porta A e della porta B nella finestra 

Watch. 

Anche per questa operazione vi consigliamo di ri¬ 
leggere quanto spiegato nella rivista precedente 
sotto il paragrafo “Inserire una variabile nella fine¬ 
stra Watch”. 

In questo modo potrete verificare per ogni istru¬ 
zione lo stato logico dei piedini d’ingresso (porta 
A) e d’uscita (porta B). 

Eseguite tutte queste operazione potrete simulare 
le funzioni del programma. 

PRIMO TEST 

Se avete seguito quanto fin qui detto, nella finestra 
Disassembler sarà evidenziata l’istruzione: 

FFE 09 88 jp inizio 

visibile anche in fig.99. 

Cliccate sull’icona passo-passo (la 5° posta sul ri¬ 
ghello in alto vedi fig.100) fino ad arrivare all’eti¬ 
chetta ripeti visibile in fig.101 cioè: 

8B6 OD D8 FE ripeti Idi wdog,FEH 


Project Debug Run Tools Registers Configure Window Help 

[jgl | |IT1 [\ f¥Tì>CR>l g]_ 


Fig.100 Ogni volta che si clicca sull’icona 
passo-passo viene eseguita una sola istru¬ 
zione del programma. 


Prima di proseguire riteniamo necessario ricordar¬ 
vi che il programma BTEST utilizza: 

- i quattro piedini PAO - PAI - PA2 - PA3 della por¬ 
ta A come ingressi 

- i quattro piedini PBO - PB1 - PB2 - PB3 della por¬ 
ta B come uscite 

Una delle funzioni del programma serve a portare 
a livello logico 1 un piedino d’uscita quando sul 
corrispondente piedino d’ingresso viene applicato 

un livello logico 1. 

Portiamo un esempio: questo programma potreb¬ 
be essere usato per accendere un diodo led o per 
polarizzare la Base di un transistor, in modo che 
ecciti un relè, collegato su un piedino d’uscita 
quando si preme un pulsante che porta a livello 
logico 1 il corrispondente piedino d’ingresso. 
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Fig.101 Iniziamo a simulare il programma B- 
TEST.PRJ dall’etichetta ripeti memorizzata 
all’indirizzo 8B6 (vedi colonna Add). 



Fig.102 La finestra Watch ci permette di 
controllare in qualunque momento il con¬ 
tenuto delle variabili port_a e port_b. 


Quindi se pigiamo il pulsante collegato sull’ingres¬ 
so PAI, si deve accendere il diodo led collegato 
sull’uscita PB1, e lasciandolo si deve spegnere. 
Se pigiamo il pulsante collegato sull’ingresso PA4 
si deve accendere il diodo led collegato sull’usci¬ 
ta PB4, e lasciandolo si deve spegnere. 

Ora possiamo verificare se le istruzioni rispondono 
a questa funzione. 

Dall’etichetta ripeti (vedi fig.101), cliccando sull’i¬ 
cona passo-passo per avanzare di un’istruzione, 
viene evidenziata: 


Nel nostro caso questa istruzione segnala al pro¬ 
gramma di saltare all’etichetta mainOO se il bit 0 di 
port_a, cioè se il piedino PAO, è resettato. 

Controlliamo il contenuto della porta A nella fine¬ 
stra Watch e, come potete vedere in fig.102, il con¬ 
tenuto della variabile port_a all’indirizzo CO è 00, 
quindi i piedini sono resettati. 

Se quindi avanziamo di un’altra istruzione il pro¬ 
gramma salterà all’istruzione con etichetta mainOO, 
ed in effetti premendo passo-passo viene eviden¬ 
ziata questa istruzione: 

8C3 03 CI 02 mainOO jrr 0,port_b,mains1 

Poiché PAO è resettato (livello logico 0) anche PBO 
deve essere resettato (livello logico 0), ma il pro¬ 
gramma prima di portarlo a livello logico 0 con¬ 
trolla che questa uscita non si trovi già in questa 
condizione. 

Questa istruzione ha proprio il compito di verifica- 
re se il piedino PBO di port_b è settato (livello lo¬ 
gico 1), cioè se l’ipotetico diodo led collegato a 
questo piedino è acceso, e solo in questo caso lo 
spegne, cioè porta l’uscita a livello logico 0. 

Se controllate la finestra Watch noterete che il con¬ 
tenuto della port_b all’indirizzo CI è 00. In altre 
parole il piedino è già resettato quindi non è ne¬ 
cessario resettarlo. 

Avanzando di un’istruzione il programma salta per¬ 
ciò all’istruzione con etichetta mainsl : 

8C8 OD D8 FE mainsl Idi wdog,0feh 

Questa istruzione ripristina il watchdog. 

Nota: abbiamo descritto la funzione watchdog sul¬ 
la rivista N.175/176 e poiché sappiamo che non vi 
manca nessun numero di Nuova Elettronica, non 
avrete difficoltà a rinfrescarvi la memoria. 

Cliccando sull’icona passo-passo viene eviden¬ 
ziata l’istruzione: 

8CB 83 CO 07 jrr 1,port_a,main01 


8B9 03 CO 07 jrr 0,port_a,mainOO 

L’istruzione JRR significa letteralmente fai un sal¬ 
to se il bit di una variabile è resettato, cioè se si 
trova a livello logico 0. 

Nota: per la descrizione di tutte le istruzioni del lin¬ 
guaggio Assembler rimandiamo alla rivista N.174 
che vi consigliamo di leggere attentamente. 


Come avrete già intuito, avanzando passo-passo il 
programma controlla gli altri piedini della porta A, 
cioè PAI - PA2 - PA3, ed i rispettivi piedini della por¬ 
ta B, cioè PB1 - PB2 - PB3, come ha appena fatto 
per il piedino d’ingresso PAO e quello d’uscita PBO. 
Essendo il contenuto di port_a e port_b uguale a 
0 (vedi finestra Watch), cliccando sempre su pas¬ 
so-passo alla fine del controllo il programma tor¬ 
nerà all’etichetta ripeti visibile in fig.101. 







































SECONDO TEST 


Se ci fermassimo a questo primo superficiale con¬ 
trollo potremmo affermare che il programma fun¬ 
ziona correttamente. 

Noi però sappiamo che il BTEST contiene tre er¬ 
rori, perché li abbiamo messi di proposito, quindi 
ora vi spieghiamo quali altri controlli vanno effet¬ 
tuati per testare ulteriormente il programma. 

Un’altra prova che va fatta è quella di simulare 
un interruttore, cioè portare a livello logico 1 
tutti i quattro ingressi della porta A per verifica- 
re se anche le rispettive uscite si portano a li¬ 
vello logico 1. 

Per portare a livello logico 1 gli ingressi della por¬ 
ta A attivate la finestra Data cliccando sulla scritta 
corrispondente (vedi fig.103). 

Nel paragrafo “Esecuzione in automatico” (vedi ri¬ 
vista N.184) vi abbiamo spiegato come trovare il 
valore esadecimale di un indirizzo di memoria, nel 
nostro caso il valore di port_a. 

Poiché esiste anche una strada diversa per cono¬ 
scere questo valore, riteniamo opportuno che la co¬ 
nosciate, e quindi ora ve la spieghiamo. 

Nella barra degli strumenti visibile sulla parte alta 
del monitor cliccate sulla scritta Data e nella pic¬ 
cola finestra che appare selezionate la scritta Go¬ 
to Address (vedi fig.104). 

Apparirà la finestra di dialogo di fig.105. 

Cliccate sulla freccia giù fino a trovare la variabi¬ 
le port_a e quando l’avete trovata selezionatela, 
quindi cliccate su OK (vedi fig.106). 

Nella finestra Data verrà evidenziato il valore esa¬ 
decimale 00 (vedi fig.107), che corrisponde al con¬ 
tenuto della variabile port_a. 

Cliccate nuovamente sul menu Data e selezionate 
questa volta la scritta Edit Data. 

Apparirà la finestra di dialogo di fig.108. 

Cliccate sulla scritta Bits per far apparire la fine¬ 
stra di dialogo di fig.109. 

Ora portate a livello logico 1 i quattro piedini d’in¬ 
gresso PAO - PAI - PA2 - PA3 di port_a, cliccan¬ 
do con il cursore nelle caselle 0 - 1 - 2 - 3. 

In queste caselle apparirà una V (vedi fig.110). 

Cliccate su OK per tornare alla finestra di dialogo 
Edit Data, in cui viene ora segnalato il nuovo va¬ 
lore esadecimale della variabile port_a, cioè F, 



Fig.103 Per accedere al sottomenu relativo 
ad una finestra, nel nostro caso Data, oc¬ 
corre rendere attiva la finestra cliccando sul 
nome corrispondente, cioè Data. 



Fig.104 Scegliendo il sottomenu Goto Ad¬ 
dress potrete posizionarvi direttamente sul 
valore esadecimale dell’indirizzo di memo¬ 
ria in cui è memorizzata la variabile. 



Fig.105 Nella riga Address cercate il nome 
della variabile cliccando sulla freccia giù. 



Fig.106 Quando avete selezionato la varia¬ 
bile cliccate su OK per tornare alla finestra 
Data, visibile in fig.107. 



Fig.107 In questa finestra viene evidenzia¬ 
to il valore esadecimale dell’indirizzo della 
variabile selezionata nella fig.106. 








































































che, come sapete, corrisponde al valore decimale 
15 ed al valore binario 00001111. 

Cliccate nuovamente su OK. 

Nota: Nel nostro volume Handbook a pag.372 tro¬ 
verete un articolo dedicato al linguaggio esadeci- 
male - binario - decimale e a pag.381 una Ta¬ 
bella di conversione che potrà risultarvi molto uti¬ 
le. 

A riprova di quanto detto nelle finestre Watch e Da¬ 
ta vedrete il nuovo valore assunto da port_a. 

A questo punto possiamo far ripartire il programma 
per verificare se, portando a livello logico 1 un 
piedino d’ingresso di port_a, ritroviamo un livello 
logico 1 anche sul corrispondente piedino d’usci¬ 
ta di port_b. 

Se il programma non è posizionato sull’etichetta ri¬ 
peti (vedi fig.101), attivate la finestra Disassem¬ 
bler cliccando sulla scritta corrispondente, quindi 
portate il cursore sulla scritta Disassembler sulla 
barra dei menu e cliccate così che appaia la fine¬ 
stra di fig.111 e selezionate l’opzione Set New PC. 

Nella finestra di dialogo New program counter 
cliccate sulla freccia giù posta sulla destra fino a 
quando non trovate l’etichetta ripeti, quindi sele¬ 
zionatela e cliccate su OK (vedi fig.112). 

Prima di far ripartire il programma sarà utile inse¬ 
rire un breakpoint. 

Nella finestra Disassembler cliccate due volte su 
ripeti e quando compare la finestra di dialogo di 
fig.113 cliccate sulla scritta Toggle Breakpoint. 

In questo modo a sinistra di questa istruzione ap¬ 
parirà un punto esclamativo (!) come visibile in 
fig.114. 

A questo punto potete lanciare l’esecuzione auto¬ 
matica del programma cliccando sull’icona che 
rappresenta una pagina con una freccia giù (ve¬ 
di fig.115). 

Vi accorgerete che il programma, arrivato all’eti¬ 
chetta mains3, esegue in maniera ciclica e all’in¬ 
finito (in gergo si dice che c’è un loop) un certo 
numero di istruzioni, e precisamente quelle relati¬ 
ve alla gestione dei piedini PA3 e PB3. 

Questo evento ci mette sull’avviso che tra queste 
istruzioni c’è un errore. 

Per bloccare l’esecuzione del ciclo, così da sco¬ 
prire l’errore, cliccate sull’icona stop (vedi fig.116) 
all’istruzione: 



Fig.108 Questa finestra di dialogo appare 
quando si seleziona il sottomenu Edit Data 
dal menu Data. Per cambiare lo stato logi¬ 
co dei piedini cliccate su Bits. 



Fig.109 Le caselle che interessano i piedini 
PA0 - PAI - PA2 - PA3 sono vuote perché 
questi piedini sono resettati. 



Fig.110 Per portare i piedini PA0 - PAI - PA2 
- PA3 a livello logico 1 cliccate sulle casel¬ 
le corrispondenti. 



Fig.111 II sottomenu Set New PC vi con¬ 
sente di aprire la finestra di dialogo New 
program counter (vedi fig.112). 



Fig.112 Grazie a questa finestra di dialogo 
potete far partire l’esecuzione del pro¬ 
gramma dall’etichetta ripeti. 


8EF C3 CO 07 


jrr 3, port_a,main03 




































































Se cliccando sull’icona stop non riuscite a fermar¬ 
vi su questa istruzione, utilizzate il comando Set 
New Pc del menu Disassembler (vedi fig.111). 
Nella finestra di dialogo che appare digitate l’indi¬ 
rizzo 8EF (vedi fig.117) quindi cliccate su OK. 

Ora conviene utilizzare il comando passo-passo 
per vedere dove abbiamo commesso l’errore. 

L’istruzione memorizzata all’indirizzo 8EF dice che 
se il piedino PA3 della porta A è a livello logico 
0 , il programma deve saltare all’istruzione con eti¬ 
chetta main03. 

Siccome però noi abbiamo posto questo piedino a 
livello logico 1 , cliccando su passo-passo il pro¬ 
gramma dovrebbe proseguire all’istruzione suc¬ 
cessiva e non saltare all’etichetta main03. 

Infatti cliccando su passo-passo il programma e- 
videnzia l’istruzione successiva: 

8F2 D3 CI 09 jrs 3,port_b,mains4 

Questa istruzione controlla se il piedino PB3 della 
porta Bòa livello logico 1 , e se si trova in que¬ 
sta condizione salta direttamente all’istruzione con 
etichetta mains4. 

Cliccando su passo-passo il programma non sal¬ 
ta a mains4, ma prosegue all’istruzione successi¬ 
va perché deve prima portare a livello logico 1 il 
piedino PB3: 

8F5 DB CO set 3, port_a 

Ecco dov’è l’errore. Infatti questa istruzione do¬ 
vrebbe servire a settare il bit 3 di port_b, cioè PB3, 
mentre noi abbiamo scritto erroneamente di setta- 

re il bit 3 di port_a, cioè PA3. 

In questo caso possiamo correggere l’istruzione 
apportando una modifica temporanea, così da po¬ 
ter continuare poi i nostri test, sostituendo all’indi¬ 
rizzo di port_a l’indirizzo di port_b. 

Questa modifica temporanea ci consente di pro¬ 
seguire il controllo del programma dal punto in cui 
ci troviamo senza dover ripristinare tutti i parame¬ 
tri compreso il settaggio dei piedini delle porte. 

Per capire come correggere questo errore, rive¬ 
diamo l’istruzione sbagliata: 

8F5 DB CO set 3, port_a 

L’istruzione set 3,port_a è tradotta dal compilato¬ 
re in formato intel.hex nel valore esadecimale DB 
CO, che potete vedere nella finestra Disassembler 
sotto la colonna Opcode (vedi fig.118). 



! Toggle Bieakpoint ! 
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Fig.113 Se volete inserire un breakpoint in 
una determinata istruzione, cliccate due 
volte sull’istruzione corrispondente per at¬ 
tivare questo menu di scelta rapida. 



Fig.114 Cliccando su Toggle Breakpoint di 
fig.113, a sinistra dell’istruzione apparirà un 
punto esclamativo (!). 



Fig.115 L’icona segnalata dal cursore per¬ 
mette di lanciare l’esecuzione automatica 
del programma. 



Fig.116 L’icona segnalata dal cursore per¬ 
mette di fermare l’esecuzione automatica 
del programma. 



Fig.117 Come abbiamo già detto (figg.111- 
112), potete far ripartire l’esecuzione dal 
programma da qualsiasi punto. In questo 
caso dall’Indirizzo 8EF. 






























































Fig.118 L’istruzione set 3 è tradotta dal 
compilatore nel valore DB e memorizzata 
all’Indirizzo 8F5, port_a è tradotta nel valo¬ 
re CO e memorizzata all’Indirizzo 8F6 (vedi 
colonne Opcode e Add). 


La stessa istruzione viene memorizzata all’interno 
del micro all’indirizzo 8F5 - 8F6 di Program Spa¬ 
ce (infatti se guardate la finestra del Disassembler 
sotto la colonna Add, l’istruzione seguente è me¬ 
morizzata a partire dall’indirizzo 8F7). 

In questo caso il valore DB corrisponde all’istru¬ 
zione set 3 e si trova all’indirizzo 8F5, mentre il va¬ 
lore CO corrisponde all'Indirizzo dell’operando 
port_a e si trova all’indirizzo seguente, cioè 8F6, 
pertanto è a questo indirizzo che dobbiamo opera¬ 
re la nostra modifica. 

Sostituendo nell’indirizzo di memoria 8F6 il valore 
corrispondente a port_a (cioè CO) con il valore cor¬ 
rispondente a port_b (cioè CI) elimineremo questo 
errore senza modificare il sorgente BTEST.ASM. 
Per conoscere gli indirizzi di port_a e port_b dovete 
guardare nella finestra Watch sotto la colonna Add. 

Per andare all’indirizzo 8F6 attivate la finestra Co¬ 
de cliccando sul nome corrispondente, quindi dal 
menu Code della barra degli strumenti seleziona¬ 
te il comando Goto Address (vedi fig.119). 

Nella finestra di dialogo digitate 8F6 (vedi fig.120), 
quindi cliccate su OK. 

Ritornerete così nella finestra Code dove vedrete 
evidenziato il valore CO che dovete correggere (ve¬ 
di fig.121). 

Cliccate su questo valore 2 volte e nella finestra di 
dialogo che appare (vedi fig.122) digitate CI, che 
come abbiamo già detto, è l’indirizzo di port_b. 
Cliccate su OK e nella finestra Disassembler ve¬ 
drete che l’istruzione si è modificata in: 

8F5 DB CI set 3, port_b 

Ora che abbiamo corretto questo errore possiamo 
continuare la simulazione del programma premen¬ 
do l’icona esecuzione automatica, cioè il disegno 
con la pagina e la freccia giù (vedi fig.115). 

In questo modo il programma prosegue in modo 
automatico fino all’etichetta ripeti, dove, come ri¬ 
corderete, abbiamo messo un breakpoint. 


Ora dobbiamo verificare se effettivamente quando 
i quattro piedini d’ingresso (cioè PAO - PAI - PA2 
- PA3) sono a livello logico 1 anche i quattro pie¬ 
dini di uscita (cioè PBO - PB1 - PB2 - PB3) si tro¬ 
vano a livello logico 1. 

Abbiamo una riprova visiva di ciò guardando la fi¬ 
nestra Watch, dove sia port_a sia port_b hanno lo 
stesso valore esadecimale OF che corrisponde al 
valore decimale 15 ed al valore binario 00001111, 
come potete anche vedere nella Tabella riportata a 
pag.381 del nostro volume HANDBOOK che pen¬ 
siamo sarà sempre a portata di mano. 



Fig.119 Selezionando il sottomenu Goto 
Address del menu Code aprite la finestra di 
dialogo visibile in fig.120. 



Fig.120 Poiché dovete correggere la varia¬ 
bile memorizzata all’indirizzo 8F6, digitate 
questo numero quindi date l’OK. 



Fig.121 Nella finestra Code viene eviden¬ 
ziato il valore CO, che corrisponde alla va¬ 
riabile port_a. Cliccate due volte su CO. 



Fig.122 Nella finestra Edit digitate CI, cioè 
l’indirizzo della variabile che dovete sosti¬ 
tuire che corrisponde a port_b. 

































































Un altro modo per verificare lo stato dei piedini di 
port_b è ripetere la procedura eseguita all’inizio di 
questo paragrafo per portare a livello logico 1 i 
piedini di port_a, sostituendo l’indirizzo di port_a 
con l’indirizzo di port_b, cioè sostituendo CO con 
CI. 


gono resettati i rispettivi piedini di port_a, in altre 
parole di portare a livello logico 0 i piedini d’usci¬ 
ta quando vengono posti a livello logico 0 i piedi¬ 
ni d’ingresso. 

Il terzo test si propone di verificare questa funzione. 


Attivate la finestra Data cliccando sulla scritta cor¬ 
rispondente, quindi cliccate sul menu Data della 
barra dei menu e selezionate Goto Address. 
Nella finestra di dialogo che appare cercate la va¬ 
riabile port_b, selezionatela e quindi cliccate su 
OK. 

Nella finestra Data verrà evidenziato il valore esa- 
decimale OF che corrisponde al contenuto della va¬ 
riabile port_b. 

Cliccate nuovamente sul menu Data e questa vol¬ 
ta selezionate Edit Data. 

Nella finestra di dialogo che appare cliccate sulla 
scritta Bits per aprire la finestra di dialogo visibile 
in fig.123. 



Come potete verificare, ai 4 piedini settati della por¬ 
ta A corrispondono 4 piedini settati della porta B 
(infatti le caselle 0 - 1 - 2 - 3 hanno una V). 

Uscite da questa finestra senza fare nessuna mo¬ 
difica cliccando sulla scritta Cancel. 

Vi consigliamo di eseguire in automatico una o 
due volte il programma per essere certi di non a- 
ver modificato senza volere i valori di port_a e 
port_b. 

Premete sull’icona esecuzione automatica e se tut¬ 
to procede in modo regolare il programma si fer¬ 
merà al breakpoint. 


TERZO TEST 

La seconda funzione del programma BTEST è 
quella di resettare i piedini di port_b quando ven- 


Innanzitutto se nella finestra Disassembler non 
viene evidenziata l’etichetta ripeti, cliccate sulla 
scritta Disassembler nella barra dei menu e sele¬ 
zionate Set New PC (vedi fig.111). 

Nella finestra di dialogo che appare cercate l’eti¬ 
chetta ripeti cliccando sulla freccia giù e quando 
l’avrete trovata selezionatela quindi cliccate su OK 
(vedi fig.112). 

Per resettare i piedini della porta A attivate la fi¬ 
nestra Data cliccando sul nome corrispondente. 
Cliccate sulla scritta Data della barra dei menu in 
modo che appaia la piccola finestra visibile in 
fig.124 e selezionate Goto Address. 

Se nella finestra di dialogo non compare CO, digi¬ 
tate manualmente questo indirizzo (vedi fig.125) e 
cliccate su OK. 

Ora cliccate due volte sul valore OF evidenziato 
nella finestra Data e nella finestra di dialogo che 
appare cliccate su Bits. 

Cliccando nelle caselle in cui appare la V, riporta¬ 
te tutti i piedini d’ingresso di port_a a livello logi¬ 
co 0 (le caselle 0 - 1 - 2 - 3 devono essere vuote) 
come visibile in fig.126. 

A questo punto cliccate su OK per tornare alla fi¬ 
nestra principale del DSE. 



Fig.124 Per portare a livello logico 0 i pie¬ 
dini della porta A, dal menu Data scegliete 
Goto Address. 


Goto address 


2 ^ 



Fig.125 Poiché l’indirizzo CO corrisponde a 
port_a, digitate questo valore quindi clic¬ 
cate su OK. 















































Ora potete eseguire il programma in automatico, 
cliccando cioè sull’icona con una pagina con la 
freccia in giù (vedi fig.115), e vedrete che si fer¬ 
merà al breakpoint. 

Si potrebbe supporre che il programma rispetti an¬ 
che questa funzione, ma se guardate nella finestra 
Watch (vedi fig.127) noterete che pur essendo tut¬ 
ti i piedini di port_a a livello logico 0 (valore esa- 
decimale 00) i piedini di port_b non sono tutti a li¬ 
vello logico 0 (valore esadecimale 04). 

Nel programma c’è quindi un errore. 

Se non sapete a quale valore binario corrisponde 
il valore esadecimale 04, cioè se non sapete qua¬ 
le bit è a livello logico 1, attivate la finestra Data e 
dal menu Data selezionate Goto Address. 

Nella finestra di dialogo che appare digitate l’indi¬ 
rizzo di port_b, cioè CI (vedi fig.128), poi cliccate 
su OK. 

Quindi cliccate due volte sul valore 04 evidenzia¬ 
to nella finestra Data e nella finestra di dialogo che 
appare selezionate la scritta Bits. 

Come visibile in fig.129, il piedino PB2 risulta an¬ 
cora a livello logico 1 sebbene l’ingresso corri¬ 
spondente, cioè PA2, risulti a livello logico 0. 

E’ dunque ovvio che nel programma c’è una istru¬ 
zione sbagliata, che non porta a livello logico 0 
il piedino PB2 quando il corrispondente piedino 
d’ingresso PA2 è a livello logico 0. 

Senza modificare nulla chiudete le finestre di dia¬ 
logo cliccando su Cancel. 

La gestione dei piedini PA2 e PB2 è associata all’e¬ 
tichetta mains2, quindi ricontrolliamo il programma 
partendo da questa etichetta. 

Attivate la finestra Disassembler cliccando sulla 
scritta corrispondente, quindi dal menu Disassem¬ 
bler della barra dei menu selezionate la scritta Set 
New PC (vedi fig.111). 

Cliccando sulla freccia giù cercate la scritta 
mains2 e selezionatela (vedi fig.130), poi cliccate 

su OK. 

Il programma si posizionerà sull’istruzione: 

8DA OD D8 FE mains2 Idi wdog,0FEH 

che serve a caricare il watchdog. 

A questo punto cliccate sull’icona passo-passo e 
verrà evidenziata l’istruzione successiva: 



Fig.126 Per resettare i piedini di porta A clic¬ 
cate sulle caselle 0 -1 - 2 - 3. 



Fig.127 Controllando la finestra Watch vi 
accorgerete che sebbene il contenuto di 
port_a sia 00, il contenuto di port_b è 04. 



Fig.128 Per sapere quale bit della porta B è 
a livello logico 1, in Goto Address digitate 
CI, che è l’indirizzo di port_b. 



Fig.129 II valore esadecimale 04 che ave¬ 
vate visto nella finestra Watch (fig.127) cor¬ 
risponde al piedino PB2 settato. 



Fig.130 Ricontrollate il programma parten¬ 
do dall’etichetta mains2, che gestisce i pie¬ 
dini PA2 e PB2. 


8DD 43 CO C7 


jrr 2,port_a,main02 








































































Questa istruzione significa: salta a main02 se il pie¬ 
dino 2 di port_a è resettato, cioè se PA2 si trova 

a livello logico 0. 

Siccome avevamo posto a livello logico 0 tutti gli 
ingressi della porta A, cliccando su passo-passo 
il programma salterà all’istruzione corrispondente 
all’etichetta main02: 

8E7 43 CI 02 main02 jrr 2,port_b,mains3 

Questa istruzione significa: salta a mains3 se il pie¬ 
dino 2 di port_b è resettato, cioè se PB2 è a li¬ 
vello logico 0. 

In altre parole verifica lo stato logico del piedino 
2 di port_b, perché se questo risulta già a livello 
logico 0 non lo resetta nuovamente. 

Tuttavia noi sappiamo già che questo piedino è ri¬ 
masto a livello logico 1 , perché l’abbiamo con¬ 
trollato tramite la finestra Watch (vedi figg.127 e 
129). 

Di conseguenza cliccando su passo-passo il 
programma non salta a mains3, ma prosegue 
all’istruzione successiva che resetta il piedino 

PB2: 

8EA 5B CI set 2,port_b 

Ecco dov’è l’errore: infatti il piedino non deve es¬ 
sere settato, ma resettato quindi l’istruzione er¬ 
rata è set e quella giusta è: res 2,port_b 

Su questa istruzione possiamo apportare una 
correzione temporanea anche se la correzione 
risulta un poco più complessa, perché, come a- 
vrete già intuito, non dobbiamo modificare la 
parte dell’opcode che si riferisce all’operando, 
ma quella che contiene l’istruzione vera e pro¬ 
pria. 

L’opcode dell’istruzione SET è (vedi tabella a 
pag.103): 

blIOII rr (Setta un piedino) 

L’opcode dell’istruzione RES (vedi tabella a 
pag.102) è invece: 

bOI 011 rr (Resetta un piedino) 

Il secondo byte di queste istruzioni è dato da rr, 
che corrisponde all’indirizzo dell’operando, nel no¬ 
stro caso port_b, cioè CI. 

Il primo byte dell’istruzione RES è dato da 
b+01011, dove b equivale a 3 bit che definiscono 
quale bit dell’operando da 0 a 7 deve essere re¬ 
settato mentre 01011 equivale all’istruzione res in 
binario. 


In altre parole con un numero binario di 8 bit riu¬ 
sciamo a definire l’istruzione, nel nostro caso RES 
che occupa i primi 5 bit da 0 a 4, ed il piedino a 
cui l’istruzione si riferisce, nel nostro caso il bit 2 
che occupa gli ultimi 3 bit da 5 a 7. 

posizione bit 76543210 
codice opcode — b — 0 1 0 11 


Poiché dovete resettare il bit 2, per trasformare 
questo numero decimale in un numero binario po¬ 
tete utilizzare la Tabella sotto riportata. 

Tabella N.1 



Come potete vedere il numero decimale 2 corri¬ 
sponde al numero binario 0 10. 

Pertanto per trasformare l’istruzione Set 2, che è 
errata, cioè: 

010 11011 (i 3 bit di sinistra sono b dell’opcode) 

nella corretta istruzione Res 2, dobbiamo conside¬ 
rare questo numero binario: 

010 01011 

Per convertire questo numero binario in un numero 
esadecimale potete utilizzare le tabelle di conver¬ 
sione a pag.381 del nostro volume Handbook. 

Se non disponete di questo Handbook vi convie¬ 
ne procurarvelo perché troverete spiegato come si 
fa a convertire un numero binario in un numero 
decimale o esadecimale. 

Nelle Tabelle dell’Handbook potete vedere che l’i¬ 
struzione Set 2: 

0101-1011 equivale al numero esadecimale 5B 

e che l’istruzione di Res 2: 

0100-1011 equivale al numero esadecimale 4B 

Ora che sapete come correggere l’istruzione, atti¬ 
vate la finestra Code quindi dal menu Code sele¬ 
zionate il comando Goto Address e nella finestra 







di dialogo che appare digitate 8EA (vedi fig.131), 
che è l’indirizzo di memoria Program Space corri¬ 
spondente all’istruzione set 2, port_b. 

Potete vedere questo indirizzo nella finestra Di¬ 
sassembler sotto la colonna Add. 

Se cliccate su OK, nella finestra Code verrà evi¬ 
denziato il numero 5B (vedi fig.132). 

Cliccate due volte su questo numero quindi nella 
finestra di dialogo che appare scrivete il nuovo va¬ 
lore, cioè 4B (vedi fig.133). 



Fig.131 Poiché dovete correggere l’istru¬ 
zione set 2, port_b, nella finestra Goto Ad- 
dress digitate 8EA, che è l’indirizzo di me¬ 
moria Program Space di questa istruzione. 
Quindi cliccate su OK. 
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Fig.132 Nella finestra Code viene eviden¬ 
ziato 5B, che è il valore esadecimale corri¬ 
spondente all’istruzione set 2. Cliccate due 
volte su questo valore, per aprire la finestra 
di dialogo visibile in fig.133. 



Fig.133 Ora potete correggere il valore e- 
sadecimale 5B, che equivale a set 2, con il 
valore esadecimale 4B, che equivale all’i¬ 
struzione res 2. 


Cliccate su OK e nella finestra Disassembler ve¬ 
drete che questa istruzione sarà stata modificata 
come sotto riportato: 

res 2, port_b 


Cliccate sull’icona passo-passo per far ese¬ 
guire l’istruzione e nella finestra Watch vedre¬ 
te che il valore esadecimale di port_b è diven¬ 
tato 00. 

Cliccate ora sull’icona esecuzione automatica 
(vedi fig. 115) ed il programma, eseguita qual¬ 
che istruzione, si fermerà di nuovo al break- 
point. 

Per essere sicuri di non aver variato altri valori men¬ 
tre correggevate l’istruzione, è meglio far eseguire 
il programma un paio di volte cliccando sempre su 
esecuzione automatica. 

Se non esistono altri errori il programma eseguirà 
un ciclo completo e si fermerà sempre al break- 
point. 

Durante questa fase potrete osservare nella fine¬ 
stra Watch che le variabili port_a e port_b non 
cambiano di valore. 

Anche se il programma ci conferma che non esi¬ 
stono altri errori e tutto procede regolarmente, sap¬ 
piamo che esiste un altro errore, che noi abbiamo 
volutamente inserito nel file BTEST.ASM. 

Per poter scoprire quest’ultimo errore occorre ne¬ 
cessariamente fare un quarto test. 


QUARTO TEST 

Il terzo errore da noi inserito riguarda un passag¬ 
gio insidioso e molto subdolo, perché non cambia 
la logica dell’esecuzione quindi potrebbe non es¬ 
sere mai trovato da chi non ha molta esperienza. 
Infatti malgrado ci sia questo errore il programma 
funziona correttamente. 

Posizionatevi sull’etichetta ripeti e lasciate il 

breakpoint. 

Guardate nella finestra Watch dove le variabili 
port_a e port_b dovrebbero essere a 0. 

Per trovare questo errore dovete riportare a livel¬ 
lo logico 1 il piedino PA3 di port_a 
Riteniamo che la procedura per settare i piedini di 
una porta vi sia già familiare (vedi figg.104-110), 
comunque, nel caso ancora non aveste preso con¬ 
fidenza con il programma, dovete attivare la fine¬ 
stra Data ed utilizzare il comando Goto Address 
del menu Data. Digitate il valore di port_a, cioè CO, 
quindi, dopo aver dato l’OK, cliccate due volte su 
00 poi nella finestra di dialogo che appare cliccate 
su Bits. 

Dopo aver portato a livello logico 1 il piedino PA3 
potrete uscire cliccando su OK. 
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In questo modo tornate nella finestra principale e 
vedrete nella finestra Watch che la variabile port_a 
ha valore 8 (vedi fig.134). 



Fig.134 Avendo portato a livello logico 1 il 
piedino PA3, nella finestra Watch viene e- 
videnziato il nuovo contenuto di port_a. 


A questo punto rieseguite il programma passo¬ 
passo fino all’Istruzione: 

8EC OD D8 FE mains3 Idi wdog, FEH 

che serve a caricare il watchdog. 

Premete ancora sull’Icona passo-passo per pas¬ 
sare alla istruzione successiva: 

8EF C3 CO 07 jrr 3,port_a, main03 

Questa istruzione significa: se il piedino 3 di 

port_a è resettato, cioè a livello logico 0, il pro¬ 
gramma deve saltare all’istruzione con etichetta 

main03. 

Poiché abbiamo appena posto questo piedino a li¬ 
vello logico 1, il programma non salta a main03 
ma prosegue all’istruzione successiva ed infatti 
cliccando sull’icona passo-passo viene evidenzia¬ 
ta: 

8F2 D3 CI 09 jrs 3, port_b, mains4 

Questa istruzione dice che se il piedino 3 di port_b 
è settato, cioè è a livello logico 1 , il programma 
deve saltare all’istruzione con etichetta mains4. 
Poiché questo piedino è a livello logico 0 (come 
possiamo vedere nella finestra Watch), cliccando 
passo-passo il programma prosegue all’istruzione 
successiva: 

8F5 DB CI set 3, port_b 


Il programma ha svolto regolarmente la sua fun¬ 
zione: controlla se PA3 è settato, cioè se si trova 
a livello logico 1 , poi controlla ed eventualmente 
modifica la porta d’uscita PB3. 

Per averne una verifica immediata controllate il va¬ 
lore della variabile port_b nella finestra Watch e 
vedrete che è 8 (vedi fig.134). 

A questo punto il programma dovrebbe proseguire 
andando a controllare gli ultimi piedini, cioè PA4 e 
PB4, quindi dovrebbe saltare all’istruzione con eti¬ 
chetta mains4, ma il realtà l’ultima istruzione ese¬ 
gue un salto incondizionato all’etichetta mains3 co¬ 
me potrete constatare cliccando nuovamente su 
passo-passo: 

8EC OD D8 FE mains3 Idi wdog,FEH 

Cliccando sull’icona passo-passo viene eviden¬ 
ziata l’istruzione: 

8EF C3 CO 07 jrr 3,port_a, main03 

Poiché il piedino PA3 è sempre settato cliccando 
passo-passo il programma prosegue all’istruzione 
successiva: 

8F2 D3 CI 09 jrs 3, port_b, mains4 

A questo punto però PB3 è già stato settato, quin¬ 
di premendo passo-passo il programma prosegue 
all’istruzione con etichetta mains4 per controllare 
lo stato logico degli ultimi piedini. 

In pratica il programma esegue due volte una 
serie d’istruzioni per controllare i piedini PA3 e 

PB3. 

Questo doppio controllo non crea nessun pro¬ 
blema sulla funzionalità, però se un domani ap¬ 
porterete delle modifiche al programma inserendo 
altre istruzioni proprio tra queste ultime righe che 
abbiamo analizzato, questo potrebbe crearvi dei 
grossi problemi e potrebbe diventare difficile indi¬ 
viduare l’errore. 

Ad esempio se inserite un contatore che si incre¬ 
menta di una unità ogni volta che il programma 
controlla i quattro piedini, constaterete che men¬ 
tre per gli altri piedini la somma si incrementa di 
una unità, per la routine del piedino PA3 si incre¬ 
menta di due unità perché esegue per due volte 
consecutive questa routine. 


Questa istruzione setta il piedino d’uscita PB3 e 
cliccando su passo-passo viene evidenziata: 

jp mains3 


Per rintracciare questo errore non è necessario 
che chi scrive il programma sappia a memoria tut¬ 
te le istruzioni, ma è importante che abbia ben chia¬ 
ro lo schema logico. 


8F7 C9 8E 














E’ per questo motivo che questi tipi di errori sono 
difficili da individuare. 

Per concludere l’errore subdolo è l’istruzione: 

8F7 C9 8E jp mains3 

che fa ripetere per due volte consecutive questa 
routine. 

L’istruzione va corretta con jp mains4. 

Conoscendo i 3 errori da noi inseriti nel program¬ 
ma BTEST.PRJ, possiamo andare direttamente 
nel file BTEST.ASM per correggerli tutti definitiva¬ 
mente. 

Nel caso voleste conservare gli errori presenti in 
questo programma per eventuali test, prima di ap¬ 
portare le modifiche copiate il file BTEST.ASM con 
un altro nome, ad esempio CTEST.ASM, utiliz¬ 
zando le funzioni di copia di Windows. 

Per fare le correzioni andate direttamente nell’e- 
ditor di ST6 selezionando dal menu Tools la scrit¬ 
ta ST6 (vedi fig.135). 

Apparirà così la finestra dell’editor di ST6. 
Premete F3 per aprire il file e nella finestra di dia¬ 
logo che appare selezionate BTEST.ASM (vedi 
fig.136) quindi cliccate su Open. 

Appariranno sul vostro monitor le istruzioni del pro¬ 
gramma BTEST.ASM. 

Utilizzate la freccia giù fino all’istruzione da noi nu¬ 
merata come 87 (accanto a questo numero vedre¬ 
te anche un asterisco) che corrisponde al numero 
147:1 dell’editor. 

Modificate set 2,port_b in res 2,port_b. 

Ora proseguite fino al secondo asterisco *91 (che 
corrisponde a 153:1) e modificate set 3,port_a in 
set 3,port_b. 

Infine andate al terzo asterisco *92 (che corri¬ 
sponde a 154:1) e modificate jp mains3 in jp 
mains4. 

Nella fig.137 potete vedere la parte del program¬ 
ma con le istruzioni già corrette. 

Tutte le modifiche devono essere salvate pigian¬ 
do semplicemente il tasto funzione F2. 

Poiché avete apportato delle correzioni al sorgen¬ 
te del programma, dovete ricompilarlo. 

Cliccate quindi sul menu ST6 e su Assembla (ve¬ 
di fig.138). 

Se avete apportato tutte queste modifiche in ma¬ 
niera corretta la compilazione si concluderà rego¬ 
larmente. 



Fig.135 Per correggere in maniera definiti¬ 
va il programma BTEST è necessario ap¬ 
portare le correzioni nel sorgente, cioè nel 
file BTEST.ASM. Dal DSE è possibile acce¬ 
dere direttamente all’editor dell’ST6, sce¬ 
gliendo ST6 dal menu Tools. 



Fig.136 Per aprire un file nell’editor dell’ST6 
potete usare il tasto funzione F3, che attiva 
questa finestra di dialogo. Selezionate con 
il cursore file BTEST.ASM, quindi cliccate 
su Open. 


maino2 

jrr 

2,port b,mains3 

; 86 salta a mains3 se 


res 

2,port b 

; *87 mette a 0 PB2 

mains3 





Idi 

wdog,Ofeh 

;88 ricarica il watchi 


jrr 

3,port a,main03 

;89 salta a main41 se 


jrs 

3,port b,mains4 

;90 salta a main41 se 


set 

3,port_b 

; *91 mette a 1 PB3 


jp 

mains4_ 

; *92 salta a mains4 

main03 

jrr 

3,port b,mains4 

;93 salta a mains4 se 


Fig.137 In questa figura potete vedere la 
parte del programma BTEST.ASM con le i- 
struzioni già corrette. 



Fig.138 Prima di chiudere il file dovete ri¬ 
compilare il programma BTEST.ASM, quin¬ 
di dal menu ST6 scegliete Assembla. 
















































Per tornare all’editor premete un tasto qualsiasi poi 
premete ALT+F3 per chiudere il programma BTE- 
ST.ASM ed Alt+X per uscire dall’editor di ST6. 
Rientrerete così nella finestra del DSE622 aperta 
su BTEST.PRJ e sul video comparirà un messag¬ 
gio che vi informa del fatto che il project ha una 
data precedente al sorgente del programma (vedi 
fig.139). 


Infatti avendo appena ricompilato il programma, il 
project che è attualmente attivo su DSE622 verrà 
aggiornato solo cliccando su Sì. 

In questo modo le modifiche apportate diventeran¬ 
no definitive anche in BTEST.PRJ. 

Comparirà un altro messaggio che vi avvisa che 
l'aggiornamento del project annullerà i breakpoint 
(vedi fig.140) e a questo punto potrete cliccare su 
OK. 



Fig.140 II DSE622 vi informa che l’aggior¬ 
namento del file .PRJ annullerà i break¬ 
point. Cliccate pure su OK. 


Rileggendo quanto fin qui scritto ci siamo accorti 
che la spiegazione per cercare e correggere gli er¬ 
rori con il simulatore DSE è stata abbastanza lun¬ 
ga, ma in questo modo siamo certi che questo ar¬ 
ticolo risulterà per voi molto utile perché ora sape¬ 
te in quale finestra dovete controllare i diversi li¬ 
velli logici, come si fa per trasformare un numero 
esadecimale in un decimale o in un binario, e se 
inizialmente tutto questo vi sembrerà difficile e 
complesso con un po’ di pratica capirete quanto 
invece risulti facile e semplice. 

Anche la primissime volte che avete iniziato ad an¬ 
dare in bicicletta dover rimanere in equilibrio, pe¬ 
dalare e fermarsi, potevano sembrare manovre dif¬ 
ficilissime, poi con un poco di perseveranza e di 
pratica riuscite ora a pedalare anche controllando 
il manubrio con una sola mano. 



Fig.139 Per aggiornare le modifiche anche 
sul file BTEST.PRJ dovete cliccare su Sì. 










































Alcuni lettori ci hanno inviato valide solu¬ 
zioni per far girare sotto Windows 95 il pro¬ 
gramma ST6PGM della SGS-Thomson e per 
richiamare velocemente il sistema operativo 
MS-DOS. Noi ve le proponiamo per poter ri¬ 
solvere i problemi che ora riscontrate. 


Windows 95 e ST6 


rr 

L s 


Sulla rivista N.183 vi avevamo proposto una velo¬ 
ce soluzione per riuscire a caricare ed utilizzare, 
pur avendo installato WINDOWS 95, i programmi 
che utilizzano il sistema operativo MS-DOS 6.2. 

Infatti a causa dei problemi incontrati nel caricare i 
“vecchi” programmi qualcuno aveva addirittura ab¬ 
bandonato WINDOWS 95 ed era ritornato a Win¬ 
dows 3.1. 

Tra i nostri lettori però ci sono anche dei softwari¬ 
sti molto esperti che hanno cercato e trovato solu¬ 
zioni alternative alla nostra e subito hanno provve¬ 
duto a segnalarcele affinché potessimo renderle di 
dominio pubblico tramite la rivista. 

Tra le tante lettere che ci sono pervenute ve ne 
proponiamo oggi due che ci sembrano particolar¬ 
mente utili ed interessanti, ma non escludiamo di 
pubblicare anche le altre nei prossimi numeri. 

Fin da oggi desideriamo ringraziare tutti questi let¬ 
tori per la loro collaborazione. 

Sig. Luca Montefiore - Teramo 

La prima proposta ci viene dal Sig. Luca Monte- 
fiore che è riuscito a lanciare il programma 
ST6PGM.BAT, scritto per i microprocessori ST6, 
sotto Windows 95 aggiungendo semplicemente u- 
na riga di istruzione al file CONFIG.SYS. 

Se anche a voi interessa aggiungere questa riga 
dovete procedere come segue: 

- Quando siete in Windows 95 portate il cursore 
sulla scritta Avvio (vedi fig.1) e cliccate. Nella fi¬ 
nestra che appare scegliete Programmi e nel me¬ 
nu a destra portate il cursore su Gestione Risor¬ 
se quindi cliccate (vedi fig.2). 
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Fig. 1 
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- A sinistra della finestra che appare selezionate 
l’unità Ms-dos_6 (C) (vedi fig.3), quindi attivate il 
menu a tendina di Visualizza e cliccate su Opzio¬ 
ni (vedi fig.4). 

- Nella finestra di dialogo che appare scegliete Tut- 
ti i file cliccando con il mouse sul cerchietto visi¬ 
bile in fig.5, poi portate il cursore sulla scritta OK e 
cliccate. Nella finestra a destra vedrete apparire tut¬ 
ti i file, compresi quelli nascosti. 


- Utilizzate il tasto freccia giù per cercare il file 
CONFIG.SYS e quando l’avete trovato seleziona¬ 
telo cliccando una sola volta con il tasto destro 
del mouse. 
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Fig. 7 
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Fig. 9 

- Nel menu che appare cliccate sulla scritta Pro¬ 
prietà (vedi fig.6) e quando appare la finestra di 
dialogo visibile in fig.7 controllate che non siano 
selezionate le opzioni solo lettura e nascosto, nel 
qual caso cliccate nelle rispettive caselle per to¬ 
gliere la selezione. 

- Dopo questa verifica cliccate su OK (vedi fig.7) 
per tornare al file CONFIG.SYS (vedi fig.8) che sarà 
ancora selezionato e cliccate due volte ma con il 
tasto sinistro del Mouse. 

- Apparirà la finestra di dialogo Apri con (vedi fig.9) 
in cui dovrete selezionare uno di questi programmi 

































































































Fig. 10 

di gestione testi, EDIT, NOTEPAD, WINWORD. 

Poiché questi programmi sono equivalenti potrete 
indifferentemente scegliere l’uno o l’altro cliccando 
due volte sul nome corrispondente. 

Noi abbiamo usato Edit. 

- Nell’ultima riga del programma dovete inserire l’i¬ 
struzione SWITCHES /C come visibile in fig.10. 

- Per salvare il file cliccate sul menu File, poi cuc¬ 



cate sulla scritta SALVA (vedi fig.11) ed uscite 


Fig. 11 



- A questo punto dovete nuovamente ripristinare 
l’opzione di file nascosti, perché se questo file di 
sistema rimane visualizzato potreste per errore 
cancellarlo o modificarlo. 

- Sulla barra dei menu posta in alto cliccate su Vi¬ 
sualizza e dal menu che appare scegliete la scrit¬ 
ta Opzioni e cliccate nuovamente. Nella finestra 
che appare cliccate sul cerchietto posto a sinistra 
della scritta Non visualizzare i file tipo (vedi 
fig.12) in modo che appaia un punto. Per chiude¬ 
re questa finestra cliccate su OK. 

- Uscite dal programma Gestione Risorse, chiu¬ 
dete Windows 95 quindi ricaricatelo. 

A questo punto la modifica proposta dal Sig. Mon- 
tefiore sarà operativa. 


Sig. Fabio Chiribiri - Marola (La Spezia) 

La seconda proposta che sottoponiamo alla vostra 
attenzione ci viene dal Sig. Fabio Chiribiri che è 
riuscito a richiamare il sistema operativo MS-DOS 
6.2 senza utilizzare il tasto funzione F8. 

Sulla rivista N.183 vi avevamo spiegato che pre¬ 
mendo il tasto funzione F8 si attivava un menu 
col quale era possibile scegliere tra varie moda¬ 
lità di caricamento sia di WINDOWS sia di MS- 

DOS. 

Questo tasto doveva essere premuto al momento 
giusto altrimenti il computer si poteva bloccare. 

Il Sig. Chiribiri ci ha spiegato che modificando il fi¬ 
le MSDOS.SYS si può fare a meno di premere il 
tasto funzione F8. 

Per modificare il programma MSDOS.SYS dovete 
procedere come segue: 

- Quando siete in Windows 95 portate il cursore 
sulla scritta Avvio (vedi fig.1) e cliccate. Nella fi¬ 
nestra che appare scegliete Programmi e nel me¬ 
nu a destra portate il cursore su Gestione Risor¬ 
se quindi cliccate (vedi fig. 13). 

- A sinistra della finestra che appare selezionate 
l’unità Ms-dos_6 (C) (vedi fig.14). Ora attivate il 
menu a tendina di Visualizza e cliccate su Opzio¬ 
ni (vedi fig.15). 

- Nella finestra di dialogo che appare scegliete Tut¬ 
ti i file cliccando con il mouse sul cerchietto visi¬ 
bile in fig.16, poi portate il cursore sulla scritta OK 
e cliccate. Nella finestra a destra vedrete apparire 
tutti i file, compresi quelli nascosti. 


Fig. 12 
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Fig. 15 



Fig. 16 


- Utilizzate il tasto freccia giù per cercare il file 
MSDOS.SYS e quando l’avrete trovato selezionatelo 
cliccando una sola volta con il tasto destro del mouse. 

- Nel menu che appare cliccate sulla scritta Pro¬ 
prietà (vedi fig.17) e quando appare la finestra di 
dialogo visibile in fig.18 controllate che non siano 
selezionate le opzioni solo lettura e nascosto, nel 
qual caso cliccate nelle rispettive caselle per to¬ 
gliere la selezione. 

- Dopo questa verifica cliccate su OK (vedi fig. 18) 
per tornare al file MSDOS.SYS (vedi fig.19) che 
sarà ancora selezionato e cliccate due volte ma 
con il tasto sinistro del Mouse. 
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Fig. 18 
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- Apparirà la finestra di dialogo Apri con (vedi 
fig.20) in cui dovrete selezionare uno di questi pro¬ 
grammi di gestione testi, EDIT, NOTEPAD, 
WINWORD. Poiché questi programmi sono equi¬ 
valenti potrete indifferentemente scegliere l’uno o 
l’altro cliccando due volte sul nome corrisponden¬ 
te. Noi abbiamo usato Edit. 



Fig. 20 

- Sotto la scritta [Options] dovrebbero apparire 
queste due scritte: 

BootGui=1 

BootMulti=1 


Noi abbiamo scelto un tempo di 10 secondi, ma 
potete dare a questa variabile un altro valore. 
Scaduto questo tempo, se non avete scelto nes¬ 
suna modalità, viene automaticamente avviato 
Windows 95 in modalità normale. 

Nota: se non desiderate far apparire il logo di Win¬ 
dows 95 inserite in coda alle altre la scritta Logo=0 
(vedi fig.22). 



Fig. 22 


Salvate il file utilizzando il comando Salva dal me¬ 
nu File ed uscite. 

- Siccome MSDOS.SYS oltre ad essere un file na¬ 
scosto è un file di sola lettura, dovete cliccare una 
volta con il tasto destro del mouse sulla scritta M- 
SDOS.SYS poi selezionare Proprietà (vedi fig.17). 

- Nella finestra di dialogo che appare cliccate ac¬ 
canto alla scritta sola lettura per ripristinare que¬ 
sta opzione, poi cliccate su OK (vedi fig.18). 


Se non compare BootMulti=1 dovete necessaria¬ 
mente inserirla. Le altre scritte che dovete inserire 
come visibile in fig.21 sono: 

BootMenu=1 
BootMenu Delay=10 



Fig. 21 

L’opzione BootMenu=1 ci mostra automaticamen¬ 
te ad ogni avvio il menu delle modalità di carica¬ 
mento di MS-DOS e di Windows 95 senza pre¬ 
mere F8. 

L’opzione BootMenuDelay stabilisce per quanto 
tempo, espresso in secondi, questo menu deve ri¬ 
manere a video. 


- Ora cliccate sulla scritta Visualizza del menu di 

Gestione Risorse e selezionate Opzioni (vedi 
fig. 15). 

- Nella finestra di dialogo che appare ripristinate la 
condizione di file nascosti cliccando sul cerchietto, 
quindi uscite cliccando su OK (vedi fig.23). 



Fig. 23 

- Uscite dal programma Gestione Risorse, chiu¬ 
dete Windows 95 quindi ricaricatelo. 

A questo punto la modifica proposta dal Sig. Chi- 
ribiri sarà operativa. 




























































Anche se negli ultimi numeri della rivista non sono 
apparsi degli articoli relativi al microprocessore 
ST6, non pensate volessimo abbandonarlo. 
Purtroppo dobbiamo accontentare anche quei let¬ 
tori che non vogliono sentir parlare di computer, di 
software e di microprocessori, ma solamente di pro¬ 
getti Hi-Fi, oppure di ricevitori, microspie, strumenti 
di misura, ecc. 

Ad ogni modo durante questa pausa forzata ci so¬ 
no state richieste da parte di Istituti Tecnici e pic¬ 
cole Industrie una infinità di spiegazioni supple¬ 
mentari e ciò significa che abbiamo spiegato poco 
o in modo non sufficientemente comprensibile. 

Prendendo spunto da tutte le domande ricevute og¬ 
gi vogliamo “tentare” di darvi delle spiegazioni più 
chiare, avvertendovi al tempo stesso di non fare 
troppo affidamento in quanto riportato nei diversi 
manuali per ST6. 


level (vedi Riv.184). 

3° passo o ciclo - il microprocessore memorizza 
nel registro di Stack 1 l’indirizzo di Program Spa¬ 
ce nell’istruzione che si trova immediatamente do¬ 
po l’istruzione cali. 

4° passo o ciclo - il microprocessore muove nel 
PC (Program Counter) l’indirizzo della subroutine 
della cali. 

L’istruzione ret esegue 2 cicli macchina, vale a di¬ 
re che il microprocessore quando esegue questa i- 
struzione compie 2 passi: 

1 “passo o ciclo - il microprocessore riconosce il 
codice operativo opcode della istruzione ret. 

2° ciclo - il microprocessore sposta il contenuto 
del registro Stack 1 nel PC (Program Counter) tra- 


PER PROGRAMMARE 


In quest’ultimi infatti vi sono molti errori e nessuna 
errata corrige, quindi in presenza di un insucces¬ 
so si è indotti ad autoaccusarsi di incapacità, men¬ 
tre la colpa è di chi pubblica questi manuali senza 
aver mai visto o utilizzato in pratica un solo ST6. 


I CICLI MACCHINA 

Nella rivista N.185 vi abbiamo spiegato che per ci¬ 
cli macchina si intende il numero di passi neces¬ 
sari al micro per eseguire un’istruzione. 

Poiché questa nostra spiegazione non è stata per 
tutti sufficientemente chiara, cercheremo di illu- 
strarvela meglio con un semplice esempio. 

Prendiamo in considerazione due istruzioni molto 
utilizzate in un programma, cioè cali e ret. 

L’istruzione cali esegue 4 cicli macchina, vale a 
dire che il microprocessore quando esegue questa 
istruzione compie 4 passi: 

1 ° passo o ciclo - il microprocessore riconosce il 
codice operativo opcode della istruzione cali. 

2° passo o ciclo - il microprocessore sposta al 
livello superiore il contenuto dei registri di 
Stack, innalzando di 1 livello anche lo Stack 


sferendo ad un livello più basso i valori contenuti 
nei rimanenti Stack (vedi Riv.184). 

Molti ci hanno chiesto quanto tempo dura un ciclo 
macchina e, poiché questo dipende dalla fre¬ 
quenza del quarzo, riportiamo la semplice opera¬ 
zione necessaria per ricavarlo: 

microsecondi = (13 : MHz) x cicli 

Se usiamo un quarzo da 8 MHz, per una istruzio¬ 
ne cali occorre un tempo di: 

(13 : 8) x 4 = 6,5 microsecondi 

e per una istruzione ret un tempo di: 

(13 : 8) x 2 = 3,25 microsecondi 

Usando un quarzo da 4 MHz i tempi raddoppiano. 

Nota = Vogliamo far presente a tutti coloro che u- 
tilizzano il Simulatore DSE622 della Softec senza 
l’emulatore, che la gestione dei registri di Stack, 
anche se viene eseguita correttamente, sul video 
appare in senso inverso a quanto sopra riportato, 
e l’indirizzo di rientro viene memorizzato nel livello 
più alto disponibile ed evidenziato con il simbolo 
>, mentre il contenuto degli altri livelli non viene tra¬ 
sferito. 




Nella rivista N.185 abbiamo pubblicato delle tabelle che vi permettono 
di decifrare le decodifiche dell’Opcode e degli Indirizzi di Memoria. Og¬ 
gi cercheremo di spiegarvi i Cicli macchina, il Watchdog, la funzione Re¬ 
set e tante altre cose. 


RESET 

Sono tanti i lettori che ci hanno chiesto perché ini¬ 
zialmente il microprocessore si posiziona nella lo¬ 
cazione FFEH di Program Space. 

Il micro si posiziona in questa locazione di memo¬ 
ria quando si verificano queste tre condizioni: 

1 ° - si alimenta il microprocessore. 

2°- viene messo un livello logico 0 sul piedino di 
Reset del microprocessore ST6. 

3° - il contatore Watchdog arriva a 0. 

In questa locazione di memoria FFEH il micropro¬ 
cessore troverà la prima istruzione che dovrà ese¬ 
guire, ad esempio Jp inizio. 



In pratica la locazione FFEH è una cella di memo¬ 
ria nella quale, durante la stesura del programma, 
è stato scritto cosa deve fare il microprocessore 
quando si attiva l’Interrupt generato dalla funzio¬ 
ne reset. 

Se volete sapere qualcosa di più sugli interrupts 
vi consigliamo di rileggere la rivista N.175/176. 

WATCHDOG 

Il Watchdog, come già vi abbiamo spiegato nella 
rivista N.174/175, è un contatore che si decre- 
menta con una frequenza legata al Clock del mi¬ 
croprocessore e che genera un reset ogni volta 
che arriva a 0. 

Per gestire il Watchdog il microprocessore utilizza 
un registro chiamato Digital Watchdog Registerche 
è formato da 8 bit come visibile in fig.1. 

Mettendo a 1 il bit C il Watchdog si attiva, mentre 
mettendolo a 0 si disattiva. 














Nei micro ST6 con estensione /SWD l’attivazione 
e la disattivazione sono gestibili tramite software, 
mentre nei micro ST6 con estensione /HWD sono 
gestite direttamente dall’hardware e quindi non si 
possono modificare tramite software. 

Nei micro con estensione /SWD se mettiamo a 0, 
tramite software, il bit denominato C, il Watchdog 
non risulta attivato e i bits T1-T2-T3-T4-T5-T6-SR 
possono essere utilizzati come timer a 7 bits. 

Quando il Watchdog viene attivato, cioè il bit C è 
a 1 , se tramite software mettiamo a 0 il bit SR, il 
microprocessore si resetta. 

Quando il Watchdog risulta attivato utilizza come 
contatore solo 6 bit, cioè quelli siglati T1-T2-T3- 
T4-T5-T6 (vedi fig.1); per questo solo particolare 
registro bisogna tener presente che il bit più si¬ 
gnificativo è il T6 e il meno significativo è il TI. 

Il peso di questi bits è perciò il seguente: 

bit TI = peso 1 
bit T2 = peso 2 
bit T3 = peso 4 
bit T4 = peso 8 
bit T5 = peso 16 
bit T6 = peso 32 

Sommando tutti questi pesi otteniamo un peso to¬ 
tale di 63 e se a questo sommiamo il ciclo 0, che 
per il Watchdog è significativo, otteniamo 64 cicli. 

Per sapere dopo quanti microsecondi il Watch¬ 
dog si decrementa di una unità dobbiamo usare 
questa formula: 

microsecondi = (1 : MHz) x 3.072 

In questa formula la frequenza MHz è quella del 
quarzo utilizzato per il Clock del microprocessore. 

Se nel nostro microprocessore è inserito un quar¬ 
zo da 8 MHz, il Watchdog sarà decrementato di 
una unità ogni: 

(1 : 8) x 3.072 = 384 microsecondi 

Poiché il numero massimo di cicli è 64, potremo 
raggiungere un massimo di: 

384 x 64 = 24.576 microsecondi 

che corrispondono a 24 millisecondi circa. 
Conoscere il tempo di decremento del Watchdog 


è molto importante, perché quando inseriamo una 
routine possiamo calcolare con buona approssi¬ 
mazione la cifra da caricare nel Watchdog Regi- 
ster, in modo che la somma dei tempi di ciclo 
macchina delle istruzioni risulti sempre minore del 
tempo totale di decremento. 

Tutto questo si fa per poter ricaricare al termine di 
una routine il Watchdog Register prima che arri¬ 
vi a 0, generando in questo modo un reset indesi¬ 
derato nel microprocessore. 

Usando questo artificio, se il microprocessore do¬ 
vesse andare in loop a causa di un impulso spu¬ 
rio, il Watchdog Register arriverebbe a 0 in un 
tempo brevissimo attivando il reset. 

Qui sotto riportiamo un esempio di calcolo effet¬ 
tuato su una routine, utilizzando un ST6 tipo /HWD 
con un quarzo da 8 MHz. 


Esempio: 


routOI 

Idi 

wdog,130 

(4) 


cali 

dsend 

(4) 


Idi 

wdog,130 

(4) 

dsend 

Id 

save1a,a 

(4) 


Id 

a.ddata 

(4) 


andi 

a,11110000b 

(4) 


Id 

port_c,a 

(4) 


res 

0,port_b 

(4) 


set 

0,port_b 

(4) 


cali 

delay 

(4) 


Id 

a,ddata 

(4) 


sia 

a 

(4) 


sia 

a 

(4) 


sia 

a 

(4) 


sia 

a 

(4) 


Id 

port_c,a 

(4) 


res 

0,port_b 

(4) 


set 

0,port_b 

(4) 


cali 

delay 

(4) 


Id 

a,save1a 

(4) 


ret 


(2) 

delay 

Idi 

dell,30 

(4) 

delay_A 

dee 

dell 

(4 x 30) 

delay_B 

jrnz 

delay_A 

(2 X 30) 

delay_C 


ret 

(2) 


Accanto ad ogni istruzione abbiamo indicato i cicli 
macchina. 

Come potete notare, nella routine dsend troviamo 
due cali delay e di conseguenza questa sub-rou¬ 
tine viene richiamata due volte. 




TI 

T2 

T3 

T4 

T5 

T6 

SR 

c 

1 

2 

4 

8 

16 

32 

RESET 

Wdg | 


Fig.1 II Watchdog utilizza come contatore i soli 6 bits indicati T1-T2-T3-T4-T5-T6. 

Come visibile nel disegno, il bit TI vale 1 e il bit T6 vale 32, quindi sommando tutti que¬ 
sti “pesi” otteniamo 63 e sommando a questi il ciclo 0 otteniamo un totale di 64. 


Quindi nel calcolo del tempo totale dovremo som¬ 
mare due volte il tempo di esecuzione della su¬ 
broutine delay. 

Iniziamo ora il conteggio dei tempi. 

- In routOI vi sono 3 istruzioni di 4 cicli macchina 
per un totale di 3 x 4 = 12 cicli, quindi otterremo 
un tempo totale di: 

12 x 1,625 microsec. = 19,50 microsec. 

- routOI richiama anche la cali dsend, quindi nel 
calcolo dovremo sommare anche i tempi di dsend. 

- Nel dsend vi sono 18 istruzioni: di queste ve ne 
sono 17 di 4 cicli macchina (17 x 4 = 68 cicli) ed 
una istruzione di 2 cicli macchina (1x2 = 2 cicli), 
quindi otterremo un tempo totale di: 

(68 + 2) x 1,625 microsec. = 113,75 microsec. 

Anche se nella subroutine delay vi sono 2 istruzio¬ 
ni di 4 cicli macchina, occorre far presente che le 
due istruzioni delay_A e delay_B vengono esegui¬ 
te 30 volte. Svolgendo i nostri calcoli otterremo: 

delay = 4 cicli macchina 
delay_A = 4 x 30 =120 cicli macchina 

delay_B = 2 x 30 = 60 cicli macchina 

delay_C = 2 cicli macchina 

Facendo la somma otterremo un totale di 186 ci¬ 
cli macchina, quindi un tempo di: 

186 x 1,625 microsec. = 302,25 microsec. 

Poiché questa subroutine viene eseguita due vol¬ 
te questo tempo raddoppierà in 604,50 microsec. 

Sommando tutti i tempi parziali otterremo un tem¬ 
po totale di esecuzione di: 


tempo routOI 19,50 

tempo dsend 113,75 

tempo delay 604,50 


tempo totale 


737,75 microsecondi 


Poiché sappiamo che un ciclo di Watchdog dura 
384 microsec., per evitare che il Watchdog vada a 
0 prima di 737,75 microsecondi dovremo neces¬ 
sariamente fargli fare 2 cicli in modo da ottenere 
un tempo totale di 384 x 2 = 768 microsecondi. 

A questo punto sembrerebbe logico che per fare e- 
seguire 2 cicli al Watchdog occorra caricare sul 
suo registro il numero 2, invece dovremo carica¬ 
re un numero inferiore di una unità, cioè 2-1 = 1 
essendo necessario conteggiare anche il ciclo 0. 
Al valore così ottenuto dobbiamo poi sempre som¬ 
mare 2, perchè il bit SR del Watchdog Register 
deve essere sempre a 1 altrimenti il microproces¬ 
sore si resetta. 

Quindi nella prima istruzione per far eseguire 2 ci¬ 
cli dovremo scrivere: 

routOI Idi wdog,130 

Se volessimo eseguire 4 cicli dovremmo scrivere: 

routOI Idi wdog,194 

Per eseguire 11 cicli dovremmo scrivere: 

routOI Idi wdog,82 

A questo punto vi chiederete perché per 2 cicli ab¬ 
biamo scritto wdog,130, per 4 cicli abbiamo scrit¬ 
to wdog,194, mentre per 11 cicli abbiamo scritto 

wdog,82. 

Per farvelo capire utilizziamo la tabella qui sotto ri¬ 
portata: 

Tabella di corrispondenza Pesi/Cicli 



Poiché per ottenere 2 cicli dobbiamo fare 2-1= 1, 
basta guardare nella riga sotto per scoprire che il 
numero 1 corrisponde ad peso binario 128. 

Al valore ottenuto ora dobbiamo sommare 2 per¬ 
chè il bit SR sia sempre settato a 1 , perciò avremo 
128+2 = 130. 




































Per ottenere 4 cicli dobbiamo fare 4-1 = 3, ma guar¬ 
dando la riga sotto non troveremo questo nume¬ 
ro, quindi per ottenerlo dovremo necessariamente 
sommare 1+2 = 3 e poiché il numero 1 corrispon¬ 
de ad un peso binario di 128 e il numero 2 ad un 
peso binario di 64, dovremo fare la somma di que¬ 
sti due pesi (128+64 = 192). 

A questo valore andiamo ora ad aggiungere sem¬ 
pre 2 e a questo punto avrete certamente compreso 
perché abbiamo scritto wdog,194. 

Per ottenere 11 cicli dobbiamo fare 11-1=10 che, 
non essendo presente nella riga sotto, potremo ot¬ 
tenere soltanto sommando 2+8 = 10 . 

Poiché 2 corrisponde ad un peso binario di 64 e 
8 corrisponde ad un peso binario di 16 dovremo 
calcolare la somma dei due pesi 64+16 = 80, ag¬ 
giungere sempre il valore 2 e di conseguenza scri¬ 
vere wdog,82. 

Per ottenere 51 cicli dovremo fare 51-1 = 50, poi 
vedere nella colonna del wdog quali numeri do¬ 
vremo sommare per ottenere 50 e qui avremo una 
sola possibilità: 

32 + 16 + 2 = 50 

Se sommeremo i pesi binari corrispondenti ai nu¬ 
meri sopra riportati otterremo 4+8+64 = 76, valore 
al quale andremo ad aggiungere 2 e quindi nel re¬ 
gistro di Watchdog scriveremo wdog,78. 


guenza dei singoli loro piedini, avviene tramite u- 
na serie di tre registri chiamati: 

pdir_a popt_a port_a (per la Porta A) 

pdir_b popt_b port_b (per la Porta B) 

pdir_c popt_c port_c (per la Porta C) 

Nella Tabella N.3 riportiamo cosa bisogna scrive¬ 

re nei tre registri pdir - popt - port per predispor¬ 
re questi piedini come Ingressi o come Uscite. 

Quando si scrive un programma, si dovrebbe cer¬ 
care di utilizzare i piedini di ogni singola porta tut¬ 
ti come Ingressi oppure tutti come Uscite. 

Poiché spesso ci si trova nella necessità di utiliz¬ 
zare i piedini della stessa porta alcuni come In¬ 
gressi e altri come Uscite, non è consigliabile u- 
sare le istruzioni SET(Set Bits) e RES(Reset Bits) 
direttamente sulla porta che stiamo gestendo, per¬ 
ché il microprocessore potrebbe generare dei falsi 
impulsi sui piedini compromettendo la corretta e- 
secuzione del programma. 

Un piccolo stratagemma per ovviare a questo in¬ 
conveniente è quello di utilizzare una variabile de¬ 
finita in Data Space come area di parcheggio, ca¬ 
ricare al suo interno il contenuto del registro della 
porta, settare o resettare il bit relativo e infine co¬ 
piare nuovamente il contenuto nel registro della 
porta come qui sotto riportato: 


Se scriveremo wdog,254 eseguiremo il massimo 
dei cicli, cioè 64, ma, come già abbiamo accenna¬ 
to, se il microprocessore va in loop dovremo at¬ 
tendere molto tempo prima che si resetti. 

Nota = Quando il Watchdog è attivo, se in un pro¬ 
gramma abbiamo inserito l’istruzione stop, il mi¬ 
croprocessore esegue al suo posto l’istruzione wait 
e non blocca il Clock (rivista N.174). 


save_pa 


def xxx 


Id a,port_a 

Id save_pa,a 

set 1 ,save_pa 


oppure (res 1,save_pa) 

Id a,save_pa 

Id port_a,a 


GESTIONE OTTIMALE delle PORTE 

Tutti i micro con 20 piedini (vedi fig.2) hanno due 
porte Input-Output contraddistinte da A-B. 

Tutti i micro con 28 piedini (vedi fig.3) hanno tre 
porte Input-Output contraddistinte da A-B-C. 

Come noterete, i terminali della porta A sono si¬ 
glati A0-A1-A2, ecc., quelli della porta B sono si¬ 
glati B0-B1-B2, ecc., e quelli della porta C sono si¬ 
glati C4-C5-C6-C7. 

Come già vi abbiamo spiegato nella rivista 
N.174/175 (sarebbe opportuno rileggerla), la con¬ 
figurazione e l’utilizzo di queste porte e di conse¬ 


Nota = Il passaggio dati da una variabile ad un’al¬ 
tra, come ben sapete, deve avvenire tramite l’uti¬ 
lizzo intermedio dell’accumulatore a. 

Vi sono tanti altri casi in cui si possono generare 
degli errori e falsi impulsi sui piedini della stessa 
porta; ad esempio quando nel corso di un pro¬ 
gramma si passa più volte da Ingressi a Uscita e 
viceversa, come spesso avviene quando, dialo¬ 
gando con un integrato esterno, inviamo un treno 
di dati e lo stesso integrato ce li rimanda per po¬ 
terli leggere. 

Se non si eseguono dei passaggi con un ordine 
ben definito si verificheranno sempre degli errori. 

Questi passaggi sono visibili in fig.5. 


TABELLA N.1 per micro ST62/E10 - ST62/E20 e per micro ST6/T10 - ST6/T20 


porta 

AO 

Al 

A2 

A3 

BO 

B1 

B2 

B3 

B4 

B5 

B6 

B7 

piedino 

19 

18 

17 

16 

15 

14 

13 

12 

11 

10 

9 

8 



AO 

Al 

A2 

A3 


BO 

B1 

B2 

B3 

B4 

B5 

B6 

B7 



Fig.2 AITinterno dei micro della 
serie T10-T20 non riprogramma¬ 
bili e della serie E10-E20 che so¬ 
no riprogrammabili, troviamo due 
sole porte indicate A-B. 

Nella Tabella soprariportata ab¬ 
biamo indicato a quale numero di 
piedino corrispondono le due 
porte A-B. 


TABELLA N.2 per micro ST62/E15 - ST62/E25 e per micro ST62/T15 - ST62/T25 


porta 

AO 

Al 

A2 

A3 

A4 

A5 

A6 

A7 

B0 

B1 

B2 

B3 

B4 

B5 

B6 

B7 

C4 

C5 

C6 

C7 

piedino 

27 

26 

25 

24 

23 

22 

21 

20 

19 

18 

17 

16 

15 

14 

13 

12 

9 

8 

7 

6 



Fig.3 AITinterno dei micro della 
serie T15-T25 non riprogramma¬ 
bili e della serie E15-E25 che so¬ 
no riprogrammabili, troviamo tre 
porte indicate A-B-C. 

Nella Tabella soprariportata ab¬ 
biamo indicato a quale numero di 
piedino corrispondono le tre por¬ 
te A-B-C. 


TABELLA N.3 per predisporre gli ingressi e le uscite 



INGRESSI 


senza 

pull-up 

con 

interrupt 

segnali 

analogici 














USCITE 

open 

collector 

uscita 

push-pull 














Fig.4 In questa Tabella indichiamo il numero che occorre scrivere nei tre registri “pdir-popt-port” 
per far funzionare una porta come Ingresso o come Uscita. Per settare un piedino come IN¬ 
GRESSO con PULL-UP dovremo scrivere nei tre registri 0-0-0. 


























































































Per spiegarci meglio, se dalla configurazione: 

- Ingresso Pull-Up 000 

volessimo passare alla configurazione: 

- Uscita Push-Pull 111 

dovremmo effettuare questi passaggi di configura¬ 
zione: 

000-100-110-111 oppure 000-001-101-111 

Se passeremo direttamente da 000 a 111 o se fa¬ 
remo 000-100-111, ci ritroveremo con un pro¬ 
gramma che potrebbe generare delle anomalie. 
Se da un’Uscita Push-Pull 111 volessimo passa¬ 
re direttamente ad un Ingresso Pull-up con Inter- 
rupt 010 dovremmo effettuare queste configura¬ 
zioni: 

111 - 101 - 001 - 000-010 

oppure seguire l’altra configurazione, cioè: 

111 - 110 - 100 - 000-010 

Osservando le frecce presenti nella fig.5 in cia¬ 
scuna di queste configurazioni, si può facilmente 
comprendere qual è la strada da seguire per pas¬ 
sare da una configurazione all’altra. 


INTERRUPT INPUT INPUT ANALOG 

PULL-UP PULL-UP NO PULL-UP IN 

Cjj ^ C ^ wC ^ C™ ) 

0 0 

° pen ° pen 

COLLECTOR COLLECTOR 

0 $ 

ss st 

Fig.5 In questo disegno indichiamo i pas¬ 
saggi ottimali per portarsi da una configu¬ 
razione ad un’altra (vedi Tabella N.4). Se 
non seguirete questi passaggi obbligati ot¬ 
terrete delle anomalie. 


ESPRESSIONI 

Una Espressione è costituita da numeri, da va¬ 
riabili e da operatori. 

Qui sotto riportiamo la priorità di questi operato¬ 
ri, che ci sarà utile per stabilire l’ordine di esecu¬ 
zione di calcolo nel caso fossero presenti espres¬ 
sioni con più operatori. 

Ad esempio, se nella stessa espressione troviamo 
una somma, una And e una inversione di bit, il 
compilatore eseguirà prima l’inversione di bit, poi 
la somma e per ultima la funzione And. 


Operatori 

Funzione 

Priorità 

- 

valore negativo 

1 

~ 

inversione di bit 

1 

* 

moltiplicazione 

2 

/ 

divisione 

2 

% 

modulo 

2 

» 

sposta a destra 

2 

« 

sposta a sinistra 

2 

+ 

somma 

3 

- 

sottrazione 

3 

& 

funzione And 

4 

1 

funzione Or 

6 


Dobbiamo far presente che se mettiamo delle pa¬ 
rentesi in una istruzione, ad esempio: 

Idi var1,(seg1 - offset) /4 

nonostante la divisione /4 abbia una priorità 2, vie¬ 
ne eseguita prima l’operazione segl - offset an¬ 
che se ha una priorità 3. 

Le espressioni vengono eseguite quando si effet¬ 
tua la Compilazione in Assembler e non durante 
l’esecuzione del programma. 

Nota = In molti degli esempi che riporteremo tro¬ 
verete delle Direttive Assembler che in seguito vi 
spiegheremo meglio, anche se nella rivista N.174 
abbiamo già accennato qualcosa in merito. 

Come noto, una istruzione Assembler è composta 
da: 

| ETICHETTA | | ISTRUZIONE*"! | OPERANDO | • | COMM. RIGA | 

L’Operando può essere costituito da una Variabi¬ 
le, un Registro, una Etichetta, un valore assolu¬ 
to, cioè un numero che può essere espresso in 
Binario, in Esadecimale o in Decimale. 

Anche una espressione può essere utilizzata co¬ 
me operando, ottenendo in questo modo il van¬ 
taggio di poter spostare dei blocchi di variabili da 
un punto ad un altro di una memoria con una so¬ 
la operazione, riducendo così eventuali errori. 

Sempre utilizzando una espressione come ope¬ 
rando, daremo al compilatore la possibilità di se¬ 
lezionare i blocchi di istruzioni di una macro e di 
includerli in un nuovo programma. 

Per farvi capire come usare una espressione co¬ 
me operando vi proponiamo alcuni esempi che po¬ 
trete inserire in un qualsiasi vostro programma di 


















prova, verificandone il risultato con il software si¬ 
mulatore che vi abbiamo presentato nelle riviste 

N.184 e N.185. 

1 ° Esempio 


In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con la funzione valore 
negativo. 


Etichetta 

Istruzione 

Operando 

segl 

.def 

088h 

offset 

.set 

-20h 

inizio 

Idi 

segl, offset 


Idi 

x,-40h 


Idi 

a,-offset 


Come si potrà notare, nella prima istruzione la Di¬ 
rettiva .def associa la variabile segl all’indirizzo di 

Data Space 088h. 

Nella seconda istruzione la Direttiva .set associa 
alla costante definita offset il valore risultante dall’ 

Espressione -20h (-32 decimale) e il compilato¬ 
re lo converte in EOh (224 decimale): questo per¬ 
ché la funzione valore negativo genera il com¬ 
plemento a 256 di 32 che corrisponde a 224. 

Nella terza istruzione, all’etichetta inizio, Idi carica 
nella variabile segl il valore associato a offset e 
cioè EOh. 

Nella quarta, l’istruzione Idi carica nel registro x il 
valore risultante dalla Espressione -40h (-64 in 
decimale) e il compilatore lo converte in COh (192 
decimale), perché anche in questo caso genera il 

complemento a 256 di 64 che corrisponde a 192. 

Nella quinta, l’istruzione Idi carica nell’accumula¬ 
tore “a” il valore risultante dalla Espressione -off¬ 
set (-224 in decimale) e il compilatore lo conver¬ 
te in 20h (32 decimale), perché anche in questo 
caso si ottiene il complemento a 256 di 224 che 
corrisponde a 32. 


Nella prima istruzione la Direttiva .def associa la 
variabile segl all’indirizzo di Data Space 088h. 

Nella seconda istruzione la Direttiva .def associa 
il valore risultante della Espressione “segl+1” al¬ 
la variabile seg2. 

Essendo segl definito all’indirizzo di memoria 
088h, l’espressione segl+1 viene semplificata du¬ 
rante la compilazione in Assembler nel numero 
esadecimale 088h + 1 = 089h. 

Questa variabile seg2 viene perciò associata 
all’indirizzo di Data Space 089h. 

Nella terza istruzione la Direttiva .def associa il va¬ 
lore risultante dalla Espressione “seg2+1 ” alla va¬ 
riabile seg3. Essendo seg2 definito all’indirizzo di 
memoria 089h, l’espressione “seg2+1” viene sem¬ 
plificata in 089h + 1 = 08Ah. 

Dichiarando le Variabili come qui sopra riportato, 
ridurremo l’errore di definire due o più variabili nel¬ 
la stessa cella di memoria. 

Nell’esempio qui sotto riportato si può notare che 
per errore la seg4 = 08ah risulta collocata nella 
stessa cella di memoria di seg3. 


segl 

.def 

088h 

seg2 

.def 

089h 

seg3 

.def 

08ah 

seg4 

.def 

08ah 


e questo errore non viene segnalato dal Compi¬ 
latore. 

Un altro vantaggio che deriva dall’utilizzo della so¬ 
luzione sopra consigliata si presenta nel caso vo¬ 
lessimo spostare la variabile di memoria segl in 
un altra cella mantenendo sempre la successione 

di seg2 e seg3. 

Infatti non saremo più costretti a modificare tutte 
tre le istruzioni, perché basterà cambiare soltanto 
la prima .def, mentre le successive si rilocano au¬ 
tomaticamente. 

I vantaggi più evidenti però li otterremo con le Di¬ 
rettive .macro e .input per l’utilizzo di moduli e di 
macro-routines. 


2° Esempio 


In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con la funzione somma. 


Etichetta 

Istruzione 

Operando 

segl 

.def 

088h 

seg2 

.def 

segl+1 

seg3 

.def 

seg2+1 


3° Esempio 

In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con le funzioni divi¬ 
sione e sottrazione. 


segl 

.def 

088h 

offset 

.set 

lOh 

inizio 

Idi 

x,(seg1 - offset)/ 2 


Etichetta 


Istruzione Operando 





















Nella prima istruzione la Direttiva .def associa la 
variabile segl all’indirizzo di Data Space 088h. 

Nella seconda istruzione la Direttiva .set associa 
alla costante offset il valore lOh. 

Nella terza istruzione contrassegnata dall’etichetta 
inizio, l’istruzione Idi carica nel registro x il risul¬ 
tato dell’espressione (segl - offset) / 2. 
L’istruzione segl - offset è stata racchiusa tra pa¬ 
rentesi perché deve essere eseguita prima della 
divisione per 2. 

Infatti, come vi abbiamo già spiegato nelle priorità, 
la divisione verrebbe altrimenti eseguita prima del¬ 
la sottrazione. 

divisione priorità 2 

sottrazione priorità 3 

Se eseguite queste istruzioni con un software si¬ 
mulatore potrete vedere all’etichetta inizio che l’e¬ 
spressione (segl - offset) / 2 è stata sostituita dal 
valore 3Ch. 

E ora vi spiegheremo il perché. 

Poiché viene data la priorità a (segl - offset), il 
compilatore Assembler eseguirà la sottrazione: 

088h - lOh = 78h 

quindi l’espressione (segl - offset) / 2 verrà 
semplificata in 78h / 2. 

Successivamente il compilatore Assembler ese¬ 
guirà la divisione 78h / 2 e come risultato finale ot¬ 
terremo 3Ch. 

Se volessimo ragionare in decimale, già sappiamo 
che i numeri esadecimali equivalgono a: 

088h = 136 decimale 
lOh = 16 decimale 

78h = 120 decimale 

3Ch = 60 decimale 

Eseguendo queste stesse operazioni in decimale 
otterremo: 

136 - 16 = 120 che corrisponde a 78h 
120:2 = 60 che corrisponde a 3Ch 

4° Esempio 

In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con le funzioni And, In¬ 
versione di bit e sposta a destra. 


Etichetta 

Istruz. 

Operando 

segl 

.def 

088h 

offset 

.set 

OFh 

valtst 

.set 

04h 

inizio 

Idi 

segl ,offset&(~(valtst»1 )) 


Nella prima istruzione la Direttiva .def associa la 
variabile segl all’indirizzo di Data Space 088h. 

Nella seconda istruzione la Direttiva .set associa 
alla costante offset il valore OFh. 

Nella terza istruzione la Direttiva .set associa alla 
costante valtst il valore 04h. 

Nella quarta, all’etichetta inizio, l’istruzione Idi ca¬ 
rica nella variabile segl il risultato della Espres¬ 
sione “offset&(~(valtst»1))”. 

Analizziamo ora questa Espressione per capire o- 
gni singola funzione. 

Subito viene data la priorità a (valtst»1) essendo 
racchiusa tra parentesi interne e viene semplifica¬ 
ta in 04h»1 = 02h. 

Infatti valtst vale 04h e l’operatore “»“ che indi¬ 
ca di spostare a destra, esegue uno shift bina¬ 
rio a destra di tante posizioni quante risultano in¬ 
dicate nell’espressione. 

Nel nostro esempio con 1 si ottiene il numero e- 

sadecimale 02h. 

Convertendo in binario il valore esadecimale 04h 
questo calcolo diventerà più comprensibile. 

04h = binario 000001 OOb 

Se ora spostiamo a destra il valore di ogni singo¬ 
lo bit otterremo: 

0000001Ob 

Se riconvertiremo questo numero da binario in e- 

sadecimale otterremo 02h. 

Perciò il compilatore Assembler semplificherà la e- 
spressione: 

offset&(~(valtst»1)) in offset&(~02h) 

Nota = Se avete dei problemi a convertire un nu¬ 
mero binario in esadecimale o decimale vi con¬ 
sigliamo di consultare il nostro volume HAND- 

BOOK a pag.372. 








Attenzione = Poiché non esiste nessun controllo 
sul numero di bits che vengono spostati a destra, 
il compilatore non segnalerà mai nessun errore. 

Quindi se spostate verso destra più di 7 bit otter¬ 
rete come risultato un valore uguale a 0. 

Se, ad esempio, nella espressione (valtst»1) scri¬ 
veremo per errore (valtst»10), come risultato ot¬ 
terremo 0. 


il compilatore Assembler l’ha semplificata in: 

Idi seg1,0Dh. 

5° Esempio 

In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con le funzioni Or e 
sposta i bits a sinistra. 


Poiché la nostra l’espressione è stata semplificata 
in offset&(~02h) la priorità passa a (~02h). 

Il compilatore Assembler eseguendo l’inversione 
della configurazione 02h (si noti il segno ~ della 
funzione inverti i bit) ci darà come risultato il valo¬ 
re esadecimale FDh. 

Convertendo in binario il valore esadecimale 02h 
questo calcolo diventerà più comprensibile: 

02h = binario 0000001 Ob 

Se ora invertiremo questi bits otterremo: 

imiioib 

Se riconvertiremo questo nuovo numero da bina¬ 
rio in esadecimale otterremo FDh. 

Quindi l’espressione offset&(~02h) verrà semplifi¬ 
cata in offset&FDh. 

Il compilatore Assembler eseguendo la funzione 
AND (si noti il segno &) tra offset (che vale 0Fh)e 
FDh otterrà come risultato ODh. 

Convertendo in binario questi due numeri esade- 
cimali ed eseguendo poi la funzione And otterre¬ 
mo: 

OFh = OOOOIIIIb 
FDh = mmoib 

risultato = 00001101 b 

Come noterete, nella funzione And solo se nella 
colonna sopra e in quella sotto è presente un va¬ 
lore logico 1 otteniamo come risultato 1. 

Ogni altra combinazione ci darà risultato 0. 

Se riconvertiamo il numero binario 00001101 b in 

esadecimale otterremo ODh. 

Pertanto la quarta istruzione : 

Idi seg1,offset&(~(valtst»1)) 


Etichetta 

Istruz. 

Operando 

segl 

.def 

088h 

offset 

.set 

80h 

valtst 

.set 

05h 

inizio 

Idi 

segl,offset (1 «valtst) 


Nella prima istruzione la Direttiva .def associa la 
variabile segl all’indirizzo di Data Space 088h. 

Nella seconda istruzione la Direttiva .set associa 
alla costante offset il valore 80h. 

Nella terza istruzione la Direttiva .set associa alla 
costante valtst il valore 05h. 

Nella quarta, all’etichetta inizio, l’istruzione Idi ca¬ 
rica nella Variabile segl il risultato della espres¬ 
sione offset | (1 «valtst). 

Analizziamo ora questa Espressione per capire o- 
gni singola funzione. 

Viene data la priorità a (1 «valtst) essendo rac¬ 
chiusa fra parentesi e viene semplificata in 20h. 

Attenzione = Con questa istruzione molti cadono 
in inganno perché pensano che si sposti di 1 bit 
verso sinistra il valore di valtst. 

Invece è il valore valtst che dice di quanti bits oc¬ 
corre spostare verso sinistra il numero decimale 1. 

Convertendo in binario il numero decimale 1 ot¬ 
terremo: 

00000001b 

Poiché il valore di valtst è 05h che in decimale e- 
quivale a 5, il compilatore sposterà di 5 posizioni, 
verso sinistra, il numero 1 : 

OOlOOOOOb 

Se convertiamo questo numero binario in esade¬ 
cimale otterremo 20h. 










Pertanto la quarta istruzione: 

Idi segl,offset| (1«valtst) 

verrà semplificata dal compilatore in: 

Idi segl,offset| 20h 

Attenzione = Il compilatore Assembler segnala 
errore di Overflow nel caso si tenti di spostare a 
sinistra bits significativi, oltre la capacità di 1 Byte. 

Ad esempio, se nel nostro numero sono presenti 
sulla sinistra quattro zeri = 00001000 potremo ef¬ 
fettuare uno spostamento solo di quattro, ottenen¬ 
do così 10000000. 

Se invece sulla sinistra del numero sono presenti 
solo due zeri = 0011100 lo spostamento potrà es¬ 
sere solo di due, ottenendo così 11100000. 

Tornando al nostro esempio, quando il compilato¬ 
re incontra l’espressione offset 1 20h, eseguendo la 
funzione OR tra offset (che vale 80h) e 20h otter¬ 
remo come risultato AOh. 

Infatti, se convertendo in binario i numeri esade- 
cimali 80h e 20h proviamo ad eseguire la funzio¬ 
ne OR, otterremo: 

80h = 1OOOOOOOb 
20h = 001OOOOOb 

risultato = 101 OOOOOb 

che convertito in esadecimale ci darà AOh. 

Come noterete nel risultato vengono riportati tutti 
gli 1 presenti nelle due colonne. 

Pertanto la quarta istruzione: 

Idi segl, offset|(1 «valtst) 

il compilatore la semplificherà in: 

Idi segl,AOh 


6° Esempio 

In questo esempio vi facciamo vedere come si può 
utilizzare una espressione con la funzione modu¬ 
lo indicata con il simbolo % che esegue una divi¬ 
sione e ci dà come risultato il resto se questo è 
presente, altrimenti ci dà come risultato 0. 



.block 

64-$%64 

dispOI 

.ascii 

“PROVA” 


Il simbolo “$” in Assembler significa Valore del 
Program Counter Relativo, perciò in fase di Com¬ 
pilazione (e non di esecuzione) al posto di “$” vie¬ 
ne inserito l’indirizzo della cella di memoria Pro¬ 
gram Space Relativa. 

Nella prima istruzione la direttiva .block definisce 
un’area di Program Space la cui estensione è il ri¬ 
sultato della Espressione 64-$%64. 

Questa espressione va letta come segue: 

- Sottrai da 64 l’eventuale resto risultante dalla di¬ 
visione fra il valore del Program Counter Relati¬ 
vo e il numero 64. 

Supponiamo che la direttiva: 

.block 64-$%64 

si trovi aH’indirizzo di memoria: 

Program Space 894h 

Il compilatore sostituirà questo indirizzo di me¬ 
moria al simbolo $ e semplificherà questa espres¬ 
sione come segue: 

.block 64-894h%64 

che espressa in decimale diventerà: 

.block 64-2196%64 

La funzione modulo ha priorità 2, mentre la fun¬ 
zione sottrazione ha priorità 3, perciò verrà svol¬ 
ta prima l’operazione 2196%64. 

Eseguendo questa operazione con la calcolatrice 
si otterrà: 

2196 : 64 = 34,3125 

Per ricavare il resto di questa divisione sarà suffi¬ 
ciente moltiplicare 0,3125 per 64: 

0,3125 x 64 = 20 

L’Espressione verrà ulteriormente semplificata co¬ 
me segue: 

.block 64-20 =44 

Come risultato finale questa direttiva definirà un’a¬ 
rea di 44 byte in Program Space a partire dall’in¬ 
dirizzo 894h. 

Vale a dire che vengono lasciati liberi 44 bytes in 


Etichetta Istruzione 


Operando 










modo da posizionare il 1 ° byte della successiva di¬ 
rettiva: 

dispOI .ascii “PROVA” 

nel 1 ° byte del blocco successivo di 64 bytes del 
Program Space. 

La direttiva .ascii definisce una stringa di caratte¬ 
re ASCII in Program Space la cui lunghezza in by¬ 
tes è definita dal numero di caratteri inseriti tra le 

virgolette, e vi associa una etichetta. 

Nel nostro esempio la stringa “PROVA” è lunga 5 
bytes, e dispOI è l’etichetta associata. 


Tutte queste operazioni sono indispensabili perché il 
microprocessore non permette di utilizzare diretta- 
mente le stringhe di dati definite in Program Space. 

Quindi se vogliamo utilizzarle dobbiamo trasferirle 
tramite un apposito registro, in un’area di memo¬ 
ria di 64 bytes definita Data Rom Window. 

Poiché quest’area ha una capacità di soli 64 by¬ 
tes, caricando una seconda stringa questa can¬ 
cellerà quella precedente e la sostituirà con i nuo¬ 
vi dati. 

A questo punto cercheremo di spiegarvi con un sem¬ 
plice esempio perché occorre far rientrare le strin¬ 
ghe di dati all’inizio di ogni blocco da 64 bytes. 


DATA ROM WIN. 


DATA ROM WIN. 


DATA ROM WIN. 


DATA ROM WIN. 
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Fig.6 Con questo esempio dei vassoi contenenti 64 pedine vogliamo spiegarvi perchè è 
necessario collocare la stringa .ASCII alTinizio del blocco successivo in cui terminano le 
“istruzioni” del programma. Poiché il micro per poter utilizzare la stringa di “dati” nel Pro¬ 
gram Space la deve prelevare da uno dei vassoi e caricare nel primo vassoio in alto del¬ 
la Data Rom Window, occorre che il primo byte di questa stringa (quadrettini azzurri) ini¬ 
zi da un blocco da 64 bytes. L’istruzione “.block” serve proprio per posizionare questa 
stringa nel “vassoio” successivo da 64 byte. Come vedesi nella seconda e terza colonna 
verticale dove non si è usato il “.block”, se trasferiamo il vassoio C o D nella Data Rom 
Window la stringa dei dati risulterà incompleta, mentre usando il “.block” (vedi ultima co¬ 
lonna di destra) riusciremo a portare nel vassoio della Data Rom Window la stringa com¬ 
pleta dei “dati” presenti nel vassoio D. 












































































































































































































































































































































Ammettiamo di avere un certo numero di vassoi in 
grado di contenere ciascuno un massimo di 64 pe¬ 
dine, che nel nostro esempio sarebbero i bytes. 

Anche l’area di memoria definita Data Rom Win- 
dow riservata per poter utilizzare i dati contenuti 
nelle tabelle è in grado di contenere un massimo 
di 64 pedine (vedi fig.6). 

Se abbiamo un programma composto da 163 pe¬ 
dine riusciremo a riempire completamente i primi 
due vassoi A-B e per metà il terzo vassoio C (ve¬ 
di fig.6) fino ad arrivare alla casella 35. 

Se di seguito inseriamo una stringa di dati compo¬ 
sta da 50 pedine (senza inserire l’espressione 
.block), queste verranno inserite partendo dalla ca¬ 
sella 36 fino ad arrivare alla casella 64 e nel suc¬ 
cessivo vassoio D l’Assemblatore inserirà le altre 
21 pedine. 

Se ora volessimo trasferire la nostra stringa di da¬ 
ti nella Data Rom Window, poiché possiamo pre¬ 
levare solo dei blocchi di 64 byte potremmo tra¬ 
sferire il solo blocco C o il solo il blocco D ed in 
questo caso avremmo sempre una stringa di dati 
spezzata ed incompleta. 

Si può ovviare a questo inconveniente facendo cal¬ 
colare all’Assemblatore lo spazio necessario per 


portare tutte le pedine della stringa nel blocco D, 
lasciando inutilizzate le caselle dalla 36 fino alla 64 
del blocco C, inserendo questa solo espressione: 

.block 64-$%64 

Avendo in questo modo collocato tutta la stringa 
nel blocco D, quando la trasferiremo nella Data 
Rom Window (vedi fig.6) il 1 ° byte della stringa 
coinciderà con il 1 ° byte della Data Rom Window. 

Importante = Come vi abbiamo spiegato, il .block 
permette di spostare tutta la stringa dei dati nel 
vassoio D (vedi fig.6). Uno dei vantaggi che offre il 
.block è quello di non doverci più preoccupare se 
nel vassoio C aggiungiamo o togliamo delle righe 
di istruzione, perchè il compilatore provvederà au¬ 
tomaticamente a calcolare l’area necessaria per fa¬ 
re saltare tutto il blocco dei dati nel vassoio D. 

A questo punto dobbiamo forzatamente interrom¬ 
pere questo articolo. Per il momento non ponetevi 
domande sul concreto utilizzo degli esempi che vi 
abbiamo presentato, ma limitatevi ad osservarne il 
risultato. 

Nel prossimo numero ci addentreremo nelle diret¬ 
tive assembler e tratteremo in pratica e con e- 
sempi le Espressioni. 



NUOVO softwaie SIMULATORE 


Chi desidera un software simulatore per testare i micro ST6 più completo 
del DSE.622 presentato nelle riviste N.184 e N.185, potrà installare sotto 
Windows 3.1 o 95 il nuovo software che qui vi presentiamo. 


Non possiamo iniziare questo articolo senza prima 
ringraziare pubblicamente il Sig. Cesarin Ivano di 
Porpetto (Udine) che ha realizzato questo softwa¬ 
re simulatore per i micro ST62 tipo 10-15-20-25 
che, oltre alle funzioni presenti normalmente nei 
software in circolazione, offre la possibilità di in¬ 
serire - variare e soprattutto memorizzare tutti i 
segnali sia sui piedini d’ingresso che su quelli di 
uscita compresi i piedini del Timer e dell’NMI. 

Con questo simulatore è infatti possibile memoriz¬ 
zare sui piedini d’ingresso di ogni singola porta, 
compresi quelli del Timer e dell’NMI, degli stati di¬ 
gitali e analogici con dei precisi tempi che possia¬ 
mo noi stessi prefissare da 0 fino ad un massimo 
di 500.000 microsecondi, condizione questa che 
consentirà di lanciare delle simulazioni Batch. 

Inoltre permette di visualizzare questi segnali me¬ 
morizzati su una valida finestra grafica e di ve¬ 
dere così sul monitor tutti gli eventi che si sono ve¬ 
rificati sui piedini del micro nell’arco di tempo di 

500.000 microsecondi. 


I segnali d’ingresso possono poi essere memoriz¬ 
zati sui files con estensione .CMD, mentre i segnali 
d’uscita sui files con estensione .DAT. 

Facciamo presente che le restanti funzioni risulta¬ 
no pressoché identiche a quanto già descritto nel¬ 
le riviste N.184 e N.185, quindi non dovete fare al¬ 
tro che rileggerle attentamente insieme a tutti gli e- 
sempi riportati. 

Chi non dispone di queste riviste potrà richiederle 
quando ordinerà il dischetto software. 

Per spiegarvi come usare questo software inizia¬ 
mo dalla videata principale di un test di esempio 
inserito dall’Autore, che apparirà chiamando il file 

PEDALI.PROG. 

Tralasciamo di spiegare come si deve procedere 
per far apparire la finestra di dialogo dell’Edit Da¬ 
ta (vedi fig.1), comunque se non lo ricordate vi con¬ 
sigliamo di prendere la rivista N.184 e di rileggere 
quanto scritto. 










































































Come noterete, sull’Edit Data di fig.1 appare il re¬ 
gistro dati di Port_B. Cliccando sui Bits apparirà 
la nuova finestra di fig.2 con la mappa binaria com¬ 
pleta di questa porta. 

Nella fig.3 vi facciamo vedere la finestra che ap¬ 
parirà facendo una Attivazione/Disattivazione di 
un BreakPoint. 

Potete trovare una esauriente spiegazione della 
funzione BreakPoint nella rivista N.148. 

L’unica differenza che noterete è che nella fig.62 
tutte le scritte sono in inglese, mentre nella fig.3 so¬ 
no riportate in italiano. 

Facciamo presente che la scritta Breakpoint e- 
quivale a Interruzione ON/OFF. 

Nelle figg.4-5-6-7 abbiamo riportato i menu dispo¬ 
nibili affinchè possiate rendervi conto delle possi¬ 
bilità che offre questo simulatore. 


per micro ST6 


I comandi supplementari che troverete in questo 
nuovo software sono: 

Dati in ingresso 

Scrivi File Dati in ingresso 

Scrivi File Dati in Uscita 

Cronologia Porte 
Scrivi Dati in Uscita 
Test I/O 

Se si attiva la funzione Dati in ingresso il pro¬ 
gramma accetta la selezione di un file solo con e- 
stensione .CMD come visibile in fig.8. 

Consigliamo di usare sempre lo stesso nome del 
programma che si desidera simulare, quindi se a- 
vete denominato il programma Tester.Hex o 
Led.Hex lo dovete chiamare Tester.CMD. o 
Led.CMD. 

Importante! Il file deve risultare presente già pri¬ 
ma di effettuare la prima simulazione, quindi lo do¬ 
vrete creare con un Editor qualsiasi sulla direc¬ 
tory di lavoro. 



Fig.1 Quando appare la finestra di dialogo 
dell’Edit Data dovete premere Bits. 



Fig.2 Automaticamente vi apparirà la fine¬ 
stra della mappa binaria della porta B. 



Fig.3 Ecco la finestra che apparirà attivan¬ 
do o disattivando un BreakPoint. 



Fig.4 Cliccando File apparirà la finestra del 
menu con l’elenco dei comandi. 
































































































Fig.5 Cuccando Esegui apparirà questa fi¬ 
nestra e tutti i relativi comandi. 



Fig.6 Cliccando Porte appariranno le tre 
funzioni che potrete eseguire. 



Fig.7 Cliccando Finestre potrete scegliere 
quali funzioni visualizzare. 



Fig.8 Cliccando nella fig.4 Dati in Ingresso 
apparirà questa finestra. 


Cliccando ora sulla funzione Cronologia Porte 
(vedi fig.6) è sottointeso che la prima volta la fine¬ 
stra di fig.9 apparirà completamente vuota. 

In questa finestra potete inserire o variare su ogni 
porta i livelli logici 1-0 oppure i livelli analogici 
come visibile in fig.10 (vedi in alto le scritte PA-PB- 
PC-Varie). 

Se selezionerete Varie, potrete agire sui piedini del 

TIMER e dell’NMI. 

Oltre agli stati logici è possibile selezionare sia la 
base dei tempi (vedi riga indicata Ampiezza) che 
l’offset (durata dell’impulso) fino ad un tempo mas¬ 
simo di 500.000 microsecondi. 

Nota = Questo tempo di 500.000 microsecondi, 

corrispondente a 0,5 secondi, che a voi può sem¬ 
brare irrisorio, per il microprocessore è un tempo 
esagerato perchè corrisponde a diverse migliaia 
di cicli macchina. 

In fig.9 abbiamo riportato un esempio grafico del¬ 
la funzione Cronologia Porte. 

Se, a questo punto, volete inserire nel programma 
di prova i dati visibili in fig.9, dovrete innanzitutto 
cliccare sulla barra di scorrimento orizzontale po¬ 
sta in basso (vedi scritta Ampiezza) e selezionare 
una base dei tempi di 12,5 msec. 

Cliccando poi sul cerchietto PB selezionerete la 
porta B e, posizionandovi con il mouse su PB0 e 
PB1, dovrete inserire i seguenti valori: 

piedino PB0 

a livello logico 1 da 0 a 25 msec. 
a livello logico 0 da 26 a 50 msec. 
a livello logico 1 da 51 a 75 msec. 
a livello logico 0 da 76 a 84 msec. 
a livello logico 1 da 85 msec. in poi 

piedino PB1 

a livello logico 0 da 0 a 37 msec. 
a livello logico 1 da 38 a 81 msec. 
a livello logico 0 da 82 msec. in poi 

Nota = Cliccando con il mouse al di sotto della li¬ 
nea tratteggiata orizzontale relativa a PB0 o PB1 
si inserisce un livello logico 0, mentre cliccando 
al di sopra si inserisce un livello logico 1. 

Per conoscere gli esatti tempi di salita e di disce¬ 
sa degli stati logici dovrete tenere premuto il tasto 
destro del mouse e, in questo modo, sul video ap¬ 
parirà una riga verticale di colore viola che po¬ 
trete spostare in orizzontale tenendo ovviamente 
sempre premuto il tasto del mouse. 

Come potete vedere infatti in fig.12, il piedino PB1 
si porta a livello logico 1 dopo 37 msec. 






































































Potrete leggere questo numero nel piccolo riqua¬ 
dro posto in alto a destra. 

Spostando la riga viola verso destra (vedi fig.13) 
potrete constatare che il piedino PB1 si porta a li¬ 
vello logico 0 dopo un tempo di 81 msec. 

In fig.14 sono riportati gli stessi stati logici di fig.9 
ma con una base tempi di 50 msec. 

Questo simulatore permette anche l'inserimento di 
segnali analogici e non soltanto di stati logici. 

Ad esempio, ammesso che nel nostro programma 
il piedino 4 della porta A sia stato predisposto co¬ 
me ingresso per un segnale analogico, poiché 
l’AD/converter dell’ST6 accetta un massimo di 5 
volt e utilizza un registro di 8 bit per la conversio¬ 
ne che corrisponde ad un numero decimale 255, 
è ovvio che 1 volt corrisponde al numero: 

255 : 5 = 51 

Ammesso di voler simulare una tensione di 3 volt 
dopo 125 microsecondi, dovrete cliccare sulla fun¬ 
zione Cronologia Porte visibile in fig.6 e, in que¬ 
sto modo, apparirà la finestra di fig.9; a questo pun¬ 
to dovrete cliccare nel cerchietto PA. 

La prima operazione da effettuare è quella di an¬ 
dare con il cursore sulla barra di scorrimento con 
la scritta Offset fino a quando sul video non ap¬ 
parirà un tempo di 125 msec. 

Se porterete il cursore sulla riga orizzontale in cor¬ 
rispondenza della scritta PA4 e poi vi sposterete fi¬ 
no ad incontrare la riga verticale in corrisponden¬ 
za dei 125 msec e qui cliccherete il mouse, appa¬ 
rirà la finestra centrale visibile in fig.10. 

All’interno del riquadro posto sulla destra scrivere¬ 
te 153 che corrisponde ad un valore di 3 volt, in¬ 
fatti 51 x 3 = 153. 

Se a questo punto cliccherete su OK apparirà la fi¬ 
nestra di fig.15 e sulla riga orizzontale della porta 
PA4 apparirà il numero 153. 

Per memorizzare tutti i segnali riportati nelle figg.9- 
15 nel file con l’estensione .CMD dovrete premere 
il tasto OK e, in tal modo, comparirà la finestra ri¬ 
prodotta in fig.11. 

Portando il cursore sull’icona File e cliccando En- 
ter apparirà la finestra di fig.4 e a questo punto sarà 
sufficiente cliccare sulla scritta: 

Scrivi File Dati in ingresso. 



Fig.9 Esempio grafico della funzione Cro¬ 
nologia Porte che permette di vedere i li¬ 
velli logici presenti sui piedini del micro. 



Fig.10 Se un piedino della porta è configu¬ 
rato Analog In, apparirà una finestra con un 
valore che potrete modificare. 
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Fig.11 Videata principale delle quattro fine¬ 
stre Assembler - Registri - Variabili - Me¬ 
moria attivabili tramite la fig.7. 





























































Fig.12 Portando nella Cronologia Porte di 
fig.9 la riga verticale su un segnale potrete 
leggere il suo tempo esatto. 



Fig.13 Per sapere quando la porta PB1 cam¬ 
bia da 1 a 0 dovrete spostare la riga verti¬ 
cale nella posizione visibile in figura. 



Fig.14 Modificando la base dei tempi da 
12,5 msec. (vedi fig.9) a 50 msec potrete au¬ 
mentare il campo di visualizzazione. 


Una volta memorizzati i dati, se si rilancia la si¬ 
mulazione del programma selezionando la funzio¬ 
ne Dati in ingresso, il simulatore, leggendo il file 
.CMD preleverà i segnali modificati e li inserirà in 
automatico nei piedini da voi assegnati senza in¬ 
terrompere la simulazione. 

In tutti gli altri normali programmi di simulazione si 
è costretti a fermare l’esecuzione, inserire le mo¬ 
difiche e poi ripartire. 

Concluse le spiegazioni relative alla funzione Dati 
in Ingresso, possiamo passare alla funzione Scri¬ 
vi Dati in Uscita. 

Portando il cursore sul menu Porte e cliccando En- 
ter apparirà la finestra di fig.6 e ovviamente qui do¬ 
vrete selezionare la riga con la scritta: 

Scrivi Dati in Uscita e cliccare 

Da questo preciso istante il simulatore memoriz¬ 
zerà tutti gli eventi presenti sui piedini del micro- 
processore configurati come uscita sia come va¬ 
lore digitale che analogico, compresa la loro du¬ 
rata. 

Il tempo massimo di memorizzazione, come già ac¬ 
cennato, non può superare i 500.000 msec che 
corrispondono esattamente a 0,5 secondi. 

Per vedere graficamente sul monitor quanto ave¬ 
te memorizzato in modo da verificare istante per i- 
stante come cambiano i livelli logici o analogici sui 
piedini delle porte e controllare così se le routine 
eseguono le funzioni da voi richieste, dovrete an¬ 
dare alla maschera di fig.6 e selezionare la riga 
Cronologia porte. 

Cliccando su questa riga comparirà la finestra vi¬ 
sibile in fig.16 dove, in rosso, appaiono tutti i livelli 
logici delle porte d’uscita. 

La barra verticale azzurra visibile sulla destra dell’e¬ 
sempio segnala il punto esatto di fine registrazio¬ 
ne eventi. 

Nel nostro caso è di 181 msec (come visibile an¬ 
che in alto a destra). 

Nel nostro esempio i segnali sono riferiti alla porta 
B, quindi se avessimo predisposto come uscita la 
porta A avremmo dovuto selezionare il cerchietto 
posto in alto con la scritta PA anziché PB. 

Per salvare definitivamente questi dati memoriz¬ 
zati dovrete premere OK e, in tal modo, riapparirà 
la finestra di fig.11 e su questa dovrete cliccare sul¬ 
la scritta File in modo da far apparire la finestra ri¬ 
prodotta in fig.4. 












































Portate il cursore sulla riga Scrivi File Dati Usci¬ 
ta, poi premete Enter e, così facendo, apparirà la 
finestra visibile in fig.17 e nel riquadro sottostante, 
in corrispondenza della scritta Nome file, inserite 
il nome del file con estensione .DAT. 

Premete infine OK. 

Nell’esempio di fig.17 abbiamo denominato questo 
file TESTER.DAT. 

Tutti i file memorizzati con estensione .DAT e an¬ 
che quelli con estensione .CMD possono essere ri¬ 
chiamati, visualizzati e stampati con un qualsiasi 
programma di Editor. 

Troverete la spiegazione della struttura dei dati 
contenuti in questi due files nelle NOTE che l’Au¬ 
tore ha inserito nel software. 

Per stampare queste note dovrete andare su File 
Manager se avete il Windows 3.1 oppure su Ri¬ 
sorse del Computer se avete Windows 95, poi vi 
dovrete posizionare nella directory in cui avete in¬ 
stallato questo software. 

In directory cercate manuale.wri, poi cliccate e 
sul monitor potrete leggere queste note. 

L’ultima funzione Test I/O serve per visualizzare 
ed eventualmente modificare la configurazione 
delle Porte e del Timer del microprocessore e an¬ 
che i livelli logici dei dati d’ingresso. 

Nella fig.18 potete vedere la maschera che com¬ 
pare sul monitor quando si attiva questa funzione. 
Osservando in basso a destra, sotto la scritta Mo¬ 
do potrete notare che è stata selezionata la fun¬ 
zione Linee che permette di visualizzare i segna¬ 
li che sono presenti sui piedini del microprocesso¬ 
re nel preciso momento in cui è stata attivata la fun¬ 
zione Test I/O. 

Sul lato sinistro è riportata la zoccolatura del mi¬ 
croprocessore (nel nostro esempio è riportata la 
zoccolatura dell’ST62/15 - ST62/25) e sul lato de¬ 
stro la piedinatura di ogni porta. 

Il segno V presente nei riquadri sta ad indicare che 
nel corrispondente piedino è presente un livello lo¬ 
gico 1. 

Ammesso di voler modificare lo stato logico del pie¬ 
dino PA2 della porta A, sarà sufficiente portare il 
cursore nel riquadro corrispondente e cliccare con 
il mouse e, così facendo, apparirà una V; se cuc¬ 
cherete una seconda volta la V sparirà. 

Se sotto la scritta Modo selezionerete la modalità 
Configurazione (vedi fig.19), vedrete come risul¬ 
tano configurate tutte le porte del micro. 

Come potete notare nel riquadro che appare sulla 
destra, tutti i piedini della porta B sono configura¬ 
ti Out Push Pulì. 

Il piedino 4 della porta A è configurato Analog In, 
mentre i restanti piedini di questa porta sono con¬ 
figurati Input Pulì Up. 



Fig.15 Poiché nel nostro esempio abbiamo 
assegnato alla porta PA4 un valore di 3 volt 
vedrete apparire il numero 153. 



Fig.16 In questo grafico potete vedere tutti 
i livelli logici 1-0 che risulteranno presenti 
sulle porte configurate Out. 



Fig.17 Per salvare in un file i segnali pre¬ 
senti sui piedini d’uscita (vedi fig.16) do¬ 
vrete utilizzare questa finestra. 




























































Fig.18 Questa finestra appare attivando la 
funzione Test I/O in Modo Linee. 



Fig.19 Questa finestra appare attivando Te¬ 
st I/O in Modo Configurazione. 



Fig.20 In fase d’installazione, quando ap¬ 
pare questo messaggio inserite il disco 2. 


Per modificare la configurazione di una porta do¬ 
vrete rispettare i valori logici che abbiamo indica¬ 
to nella Tabella N.l. 

Premendo OK uscirete da questa maschera e poi¬ 
ché avete apportato delle modifiche vi converrà sal¬ 
varle sul file con estensione .CMD tramite la fun¬ 
zione Scrivi File Data in Ingresso dopo aver fat¬ 
to apparire la maschera di fig.4. 

A questo punto rilanciate la simulazione del vo¬ 
stro programma, selezionando Dati in ingresso e 
verificando quale risultato si ottiene con le modifi¬ 
che apportate. 

INSTALLAZIONE del SOFTWARE 
sotto WINDOWS 3.1 

Inserite nell’unità floppy disk il dischetto ST622-1 e 
nel menu del Program Manager portate il cursore 
in alto a sinistra sulla scritta File e cliccate. 
Andate sulla scritta Esegui, cliccate nuovamente e 
quando apparirà la finestra di dialogo digitate: 

A:\setup poi cliccate su OK 

In questo modo il computer inizierà a leggere il con¬ 
tenuto del primo dischetto e quando questo risul¬ 
terà trasferito, apparirà la maschera di fig.20. 
Togliete il dischetto ST622-1, inserite il dischetto 
ST622-2 e a questo punto cliccate su OK. 
Completata la lettura anche di questo dischetto sul 
video apparirà la maschera di fig.21. 

Cliccate su OK per proseguire. 

Dopo qualche istante apparirà la maschera ripro¬ 
dotta in fig.22. 

Se a questo punto volete modificare la directory di 
installazione, cliccate su cambia directory e se¬ 
guite le indicazioni su video, altrimenti cliccate sull’i¬ 
cona contenente l’immagine di un computer per in¬ 
stallare il software sotto la directory c:\ST622. 
Completata l’installazione, apparirà la maschera di 
fig.23 per confermarvi che nell’hard-disk risulta in¬ 
serito questo software sotto la directory ST622. 
Come noterete, nel Program Manager verrà ge¬ 
nerata la relativa icona. 



USCITE 

open 

collector 

uscita 

push-pull 














TABELLA N.l = Per modificare la configurazione di una porta d’ingresso o di uscita do¬ 
vrete rispettare questi livelli logici. Quindi per un ingresso SENZA PULL UP dovrete as¬ 
segnare il registro DDR a 0, il registro OR a 0 e il registro DR a 1. 










































































INSTALLAZIONE del SOFTWARE 
sotto WINDOWS 95 


Installazione di ST622 


Inserite nell’unità floppy disk il dischetto ST622-1 e 
cliccate sulla scritta Avvio posta in basso a sini¬ 
stra, poi andate sulla scritta Esegui e cliccate nuo¬ 
vamente e quando apparirà la finestra di dialogo 
digitate: 

A:\setup poi cliccate su OK 

In questo modo il computer inizierà a leggere il con¬ 
tenuto del primo dischetto e quando questo risul¬ 
terà trasferito, apparirà la maschera di fig.20. 
Togliete il dischetto ST622-1, inserite il dischetto 
ST622-2 e a questo punto cliccate su OK. 
Completata la lettura anche di questo dischetto, sul 
video comparirà la maschera di fig.21. 

Cliccate su OK per proseguire. 

Dopo qualche istante, apparirà la maschera ripro¬ 
dotta in fig.22. 

Se, a questo punto, volete modificare la directory 
di installazione, cliccate su cambia directory e se¬ 
guite le indicazioni che appariranno sul video, al¬ 
trimenti cliccate sull’Icona” contenente l’immagine 
di un computer per installare il software sotto la di¬ 
rectory c:\ST622. 

Completata l’installazione apparirà la maschera di 
fig.23 per confermarvi che nel vostro hard-disk ri¬ 
sulta inserito il software sotto la directory ST622 e 
automaticamente verrà generata la relativa icona. 

Nota = Nel dischetto ST622-2 è presente una di¬ 
rectory Esempi in cui l’Autore ha inserito un pro¬ 
gramma chiamato PEDALI con varie estensioni 
(.Dat - .Cmd - .Asm, ecc.), che potranno servirvi 
per impratichirvi nell’uso del simulatore. 

In fase di installazione questa directory non viene 
copiata nell’Hard-Disk, quindi per trasferirla dovre¬ 
te usare la funzione Copy File. 

CONCLUSIONE 

Questo software simulatore sarà molto utile a tut¬ 
ti i softwaristi che programmano dei microproces¬ 
sori tipo ST6 perchè, a differenza di altri, permette 
di vedere - modificare - variare con estrema fa¬ 
cilità le condizioni logiche su tutte le porte d’in¬ 
gresso e d’uscita. 

Più prenderete confidenza con l’uso di questo 
software più vi renderete conto dei tanti problemi 
che esso è in grado di risolvere. 

COSTO del SOFTWARE 

Costo dei due dischetti floppy ST622-1 e ST622-2 
Iva inclusa.€ 10,32 



Fig.21 Se in fase d’installazione appare que¬ 
sto messaggio dovrete uscire e poi chiu¬ 
dere tutte le altre applicazioni attive. 
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Fig.22 Letti tutti e due i dischetti, il pro¬ 
gramma d’installazione chiederà se volete 
cambiare oppure no la directory. 
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Fig.23 Completata l’installazione sull’Hard 
Disk, apparirà l’icona che dovrete utilizza¬ 
re in seguito per lanciare il software. 



























































Nell’Assembler per ST62 esistono delle istruzio¬ 
ni chiamate direttive, che in pratica esauriscono 
la loro funzione in fase di compilazione e non ge¬ 
nerano, come le altre istruzioni, una OPCODE e- 
seguibile. 

In parole povere queste istruzioni non fanno ese¬ 
guire nulla al microprocessore ma agiscono solo 

sul Compilatore. 

A questo punto qualcuno si chiederà quale utilità 
possano avere queste direttive che non fanno nul¬ 
la di concreto, quindi se volete scoprirlo dovrete 
leggere questo articolo e alla fine capirete che mol¬ 
te di esse sono indispensabili. 

Per fare un esempio iniziamo dalla direttiva .di¬ 
splay che possiamo chiamare digitando: 

.display “stringa” 


Chiusa questa breve parentesi, proseguiamo ri¬ 
portando l’elenco di tutte queste Direttive. 

A quanti hanno già acquistato e utilizzato i pro¬ 
grammi didattici contenuti nei nostri dischetti mol¬ 
te di queste istruzioni risulteranno familiari. 

Vi sono ben 36 di queste direttive e qui sotto ve 
le elenchiamo raggruppate per funzioni: 


Direttive usate per la definizione 
di Dati nell’area del Programma: 


.block 

.byte 

.word 

.ascii 

.ascii 


SOFTWARE emulatore per 


Se imparerete a conoscere e ad utilizzare le Direttive dell’Assembler riu¬ 
scirete ad ottimizzare i vostri programmi, a gestire le librerie di moduli 
e di macro, a sezionare i programmi in pagine logiche, a generare mo¬ 
duli in formato .obj ecc., risparmiando così del tempo nella stesura. 


La parola stringa che abbiamo inserito tra le virgo- 
lette, può essere sostituita con una parola diversa 
oppure con una frase di messaggio, ad esempio: 

.display “Compilato routine PIPPO.ASM” 

Quando il Compilatore legge questa Direttiva, 

provvede a visualizzare sul Monitor del Computer 
la frase: 

Compilato routine PIPPO.ASM 

In questo caso è il Compilatore Assembler che 

esegue il comando .display e non l’ST6. 

In programmazione, questa tecnica di segnalazio¬ 
ne sul monitor viene molto utilizzata in combina¬ 
zione con le direttive .input oppure .macro e .ifc 
perchè consente di vedere direttamente sul moni¬ 
tor, in tempo reale, quali routine sono state carica¬ 
te nel programma in fase di Compilazione. 


Direttiva usata per la definizione 
di Variabili nell’area del Dati: 


.def 


Direttive usate per la definizione 
delle Costanti Simboliche: 


.equ 

.set 


Direttive usate per il Correlatore di Moduli 

definito anche con il nome di Linker: 


.glob 

.window 

.windowend 

.transmit 

.notransmit 













TESTARE i micro ST6 


Direttive relative al solo Hardware: 


Direttive da usare per la Compilazione 



Condizionata in Assembler: 

.pp_on 



.dp_on 


.ite 

.w_on 


.else 

.paged 


.ende 

.section 






Direttive di carattere Generale: 


Direttive da utilizzare per la 



gestione delle Macro: 

.display 



.end 


.macro 

.input 


.endm 

■org 


.mexit 

.error 



.warning 




Completato 1 elenco delle direttive, poiché non e- 


siste un ordine ben preciso per iniziare da una di¬ 

Direttive da utilizzare 

rettiva anziché da un’altra, prendiamo in conside¬ 

per impaginare il listato: 

razione quella denominata .w_on, strettamente le- 


gata alla Data Rom Window, alla quale abbiamo 

.eject 

già fatto cenno nella rivista N.189. 

.list 


■pi 

La direttiva .w_on ha un’unica funzione che consi¬ 

.linesize 

ste nell’abilitare la Data Rom Window all’interno 

.title 

del programma. 


.comment 


Se aH’inizio del programma non inseriamo la diret- 

















tiva .w_on non potremo usufruire di quest’area ed 
il Compilatore ci segnalerà: 

Error ,W_ON Directive Required 

Una volta abilitata, per accedere e utilizzare la Da¬ 
ta Rom Window dovremo inserire in coda a de¬ 
terminate istruzioni le due sigle .w e .d. 

A questo punto apriamo una parentesi per parlare 
di Data Rom Window e del suo corretto utilizzo 
tramite .w e .d. 

Già nella precedente rivista N.189 abbiamo ac¬ 
cennato che per poter utilizzare una stringa di da¬ 
ti, sia alfanumerici che numerici, definiti nel Pro¬ 
gram Space, occorre prima caricarli nella Data 
Rom Window (che è un’area di Data Space lun¬ 
ga 64 bytes che inizia dalla locazione 40h) trami¬ 
te il Data Window Register, che è un registro a 8 
bits definito alla locazione di Data Space C9h. 

Supponiamo quindi di avere un programma in cui 
abbiamo definito una serie di stringhe dati nella lo¬ 
cazione A40h di Program Space come qui sot¬ 
toriportato: 

A40h testOI .ascii “TESTO DI PROVA” 

.ascii “PER VISUALIZZARE” 
.ascii “CARATTERI ALFAN“ 
.ascii “UMERICI - FINE - “ 


Come potete notare, abbiamo definito 4 direttive .a- 
scii lunghe 16 Bytes cadauna ed alla prima ab¬ 
biamo associato l’etichetta testOI. 

Per caricare questi dati in Data Rom Window dob¬ 
biamo scrivere: 

Idi drw,testOI .w 

Nota: dopo Idi appare la variabile drw che abbia¬ 
mo utilizzato per definire il Data Window Register. 
È sottointeso che possiamo sostituire drw con 
qualsiasi altra sigla, ad esempio pippo, oppure 
regOI ed anche kkkk, importante è non superare 
8 caratteri. 

Come noterete l’etichetta testOI , che corrisponde 
al bytes di inizio della stringa, termina con .w. 

Se per errore scriviamo l’etichetta testOI senza in¬ 
serire il .w come qui sottoriportato: 

Idi drw,testOI 

il compilatore ci segnalerà questo errore: 

- 8 bit value overflow 

nel caso le stringhe di testOI risultino inserite in co¬ 
da alle istruzioni del programma. 


TABELLA N.1 di conversione binario/decimale 


bit 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

peso 

2048 

1024 

512 

256 

128 

64 

32 

16 

8 

4 

2 

1 

binario 

i 

0 

1 

0 

0 

1 

0 

0 

0 

0 

0 

0 


Il codice binario 101001.000000 posto sotto al relativo peso. 


TABELLA N.2 di conversione binario/decimale 


bit 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

peso 

2048 

1024 

512 

256 

128 

64 

32 

16 

8 

4 

2 

1 

binario 

0 

0 

0 

0 

0 

0 

1 

0 

i 

0 

0 

i 


I primi 6 numeri del codice binario 101001 sono spostati tutti verso destra. 











































Fig.1 Con il software si¬ 
mulatore potrete notare 
nella finestra del Disas¬ 
sembler, che l’istruzione: 
Idi drw,testOI .w 
si sarà tramutata in: 

Idi drw,29H 


Se invece le stringhe di testOI risultano inserite pri¬ 
ma delle istruzioni del programma, apparirà questa 
diversa scritta: 

- operand may not reference program 
space simbol testOI 

Questi errori vengono segnalati dal Compilatore 
tutte le volte che incontra una istruzione che cari¬ 
ca un indirizzo di Program Space (sempre e- 
spresso con 12 bits) in una variabile o registro in 
grado di contenere solo 8 bits. 

Inserendo invece in coda all’istruzione la sigla .w 
come qui riportato: 

Idi drw, testOI .w 

il Compilatore utilizza solo i 6 bits più significativi 
deH’indirizzo (quelli di sinistra) di Program space 
di testOI, che verranno poi caricati, in fase di ese¬ 
cuzione, nel registro drw senza generare errore. 

A questo punto dobbiamo spiegarvi come utiliz¬ 
zando solo 6 bits non si generi nessun errore. 

Se convertiamo in binario il numero esadecimale 
A40h che corrisponde all’indirizzo di testOI otter¬ 
remo: 

101001-000000 

Se collochiamo questo numero binario, composto 
di 12 bits, nella Tabella N.1 (vedi tabella a sini¬ 
stra) e sommiamo i loro i pesi otterremo: 

2048 + 512 + 64 = 2624 

Se prendiamo i 6 bits di sinistra della Tabella N.1, 
cioè 101001, e li spostiamo tutti verso destra co¬ 
me possiamo vedere nella Tabella N.2 e sommia¬ 
mo i suoi pesi otterremo: 

32 + 8 + 1 = 41 


Nota = I pesi da sommare sono solo quelli che si 
trovano a livello logico 1. 

Se ora proviamo a dividere la somma dei pesi del¬ 
la Tabella N.1 per la somma dei pesi della Tabel¬ 
la N.2 otterremo: 

2624 : 41 = 64 

In pratica quando il Compilatore assembla una i- 
struzione con .w, divide per 64 l’indirizzo di Pro¬ 
gram Space dell’etichetta: 

2624 : 64 = 41 (esadecimale 29H) 

perdendo l’eventuale resto e memorizza il risultato 
della divisione (nel nostro esempio 29H) al posto 
dell’operando testOI .w. 

Disponendo di un software simulatore (vedi fig.1) 
sarà possibile vedere, tramite la finestra Disas¬ 
sembler, che l’istruzione: 

Idi drw,testOI .w 

sarà diventata: 

Idi drw,29H 

Una volta assemblato il programma, quando il mi¬ 
croprocessore incontrerà questa istruzione il risul¬ 
tato verrà memorizzato nel Data Window Register 
che, come già saprete, deve essere tassativamen¬ 
te definito all’indirizzo di memoria Data Space C9h 
(vedi fig.2). 

In pratica l’indirizzo di testOI all’interno del registro 
drw viene espresso in 64esimi. 

Il microprocessore inoltre riconosce che il registro 
drw, definito alla locazione di memoria C9h, è il 
Data Window Register, quindi carica nella Data 
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Fig.2 II risultato della istruzione Idi drw,29H verrà memorizzato nella locazione C9h. 


Rom Window tutti i 64 bytes, cioè: 

“TESTO DI PROVA ” 

“PER VISUALIZZARE” 

“CARATTERI ALFAN" 

“UMERICI - FINE - “ 

Infatti, se prendiamo il numero 41 contenuto nel 
Data Window Register e lo moltiplichiamo per 64 
otterremo un numero decimale: 

41 x 64 = 2624 

che corrisponde al numero esadecimale A40h che 
è esattamente l’indirizzo di: 

A40h testo 1 .ascii “TESTO DI PROVA ” 
.ascii “PER VISUALIZZARE” 
.ascii “CARATTERI ALFAN" 
.ascii “UMERICI - FINE - “ 

Nota = Nel nostro esempio abbiamo volutamente 
dichiarato testOI in un indirizzo di memoria Pro¬ 
gram Space esattamente divisibile per 64, quindi, 
seguendo quanto detto sopra, testOI inizia esatta¬ 
mente nel primo byte del 41 blocco; pertanto il pri¬ 
mo byte della stringa di dati che inizia con testOI, 
verrà posizionato nel primo byte della Data Rom 
Window. 

Giunti a questo punto abbiamo memorizzato i 64 
bytes della stringa dei dati nella Data Rom Win¬ 
dow, ma per poterli utilizzare dovremo eseguire 
un’altra operazione, cioè caricare l’indirizzo del pri¬ 
mo byte di questa stringa (nel nostro esempio sa¬ 
rebbe la T affinchè la nostra stringa inizi con TE¬ 
STO) in un registro (x , y, ecc.). 

Se useremo il registro x, ogni volta che vorremo vi¬ 
sualizzare questo testo dovremo come prima i- 
struzione scrivere: 

Idi x,testOI .d 

Come noterete l’etichetta testOI è seguita da .d. 


Se per errore scriveremo: 

Idi x,testOI 

senza inserire .d in coda a testOI, il compilatore ci 
segnalerà errore dal momento che tentiamo di ca¬ 
ricare nel registro x un indirizzo di memoria Pro¬ 
gram Space. 

Scrivendo correttamente: 

Idi x,testOI .d 

quando verrà eseguita questa istruzione, nel regi¬ 
stro x verrà caricato l’indirizzo di Data Rom Win¬ 
dow di testOI e cioè 40h. 

Se notate abbiamo detto Data Rom Window e non 
Program Space come dovrebbe essere dal mo¬ 
mento che testOI (e la relativa stringa di dati) è 
stato definito inizialmente all’indirizzo A40h di Pro¬ 
gram Space. 

Quindi quando il Compilatore assembla questa i- 
struzione: 

Idi x,testOI .d 

divide l’indirizzo di Program Space di testOI per 
64, preleva il resto di questa divisione, somma a 
questo resto il valore dicimale 64 e lo memorizza 
nell’istruzione stessa al posto dell’operando te¬ 
stOI .d. 

Nel nostro caso, poiché testOI è stato definito all’in¬ 
dirizzo di Program Space A40h che corrisponde 
al valore decimale 2624, avremo: 

2624 : 64 = 41 con un resto = 0 
resto 0+64 =64 

che in esadecimale corrisponde a 40h. 

Utilizzando il software simulatore possiamo anda- 
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Fig.3 Con il software si¬ 
mulatore potrete notare 
nella finestra del Disas¬ 
sembler, che l’istruzione: 
Idi X,test01 .d 
si sarà tramutata in: 

Idi X,40H 


re nella finestra Disassembler (vedi fig.3) e qui ve¬ 
dere che l’istruzione: 

Idi x,test01.d 

sarà diventata: 

Idi x,40h 

Quando verrà lanciato il programma assemblato, 
nel registro x verrà caricato il valore 40h che cor¬ 
risponde esattamente all’Indirizzo di inizio della Da¬ 
ta Rom Window (vedi fig.4) che, nel nostro caso, 
corrisponde al primo byte della stringa: 

“TESTO DI PROVA ” 

“PER VISUALIZZARE” 

“CARATTERI ALFAN" 

“UMERICI - FINE - “ 

A questo punto con una routine ciclica che voi stes¬ 
si potrete creare, sarà possibile “muovere" la strin¬ 
ga sul display e visualizzarla. 

Molti si domanderanno che utilità pratica offre la si¬ 
gla .d cioè: 

Idi x,test01.d 

quando per caricare nel registro x il valore 40h lo 
stesso risultato lo potremmo ottenere scrivendo 
semplicemente: 

Idi x,40h 


Infatti in entrambi i casi nel registro x verrebbe sem¬ 
pre caricato l’indirizzo iniziale della Data Rom Win¬ 
dow. 

La soluzione di scrivere Idi x,40h che sembrereb¬ 
be anche la più semplice, è da scartare e con gli 
esempi che ora riporteremo ne capirete il motivo. 

Ammettiamo di avere un programma che utilizza 
un display alfanumerico composto di 2 righe di 16 
caratteri cadauna e che all’inizio occorra visualiz¬ 
zare: 

INSERIMENTO DATI 
-PROVA DISPLAY- 

poi successivamente: 

PREMI PULSANTE 
-SPEGNI DISPLAY- 

II testo da visualizzare lo abbiamo definito così 
aH’interno del programma: 


A40h 

testOI 

.ascii 

“INSERIMENTO DATI 1 

A50h 


.ascii 

“-PROVA DISPLAY- “ 

A60h 

test02 

.ascii 

“PREMI PULSANTE 

A70h 


.ascii 

“-SPEGNI DISPLAY-" 


In questo caso abbiamo 4 direttive .ascii lunghe 
ciascuna 16 bytes. 
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70 

- 55 

4D 

45 

52 

49 

43 

49 

20 

2D 

20 

46 

49 

4E 

45 

20 

2D 

CHIERICI - FINE - 

z\ 



^ m 



















Fig.4 Nel registro X verrà caricato il valore di 40H che contiene il nostro testo. 

































Abbiamo aggiunto a sinistra le locazioni di memo¬ 
ria Program Space di queste direttive, cioè: 

A40h - A50h - A60h - A70h 

Come noterete vi sono anche 2 etichette testOI e 
test02 associate rispettivamente alle locazioni Pro¬ 
gram Space A40h e A60h. 

Se ora scriviamo: 

Idi drw,testOI .w 

a partire dall’etichetta testOI verranno caricati in 

Data Rom Window tutti i 64 bytes. 

Se si dispone di un software simulatore che per¬ 
mette di visualizzare la Data Rom Window si po¬ 
trà infatti vedere memorizzato (vedi fig.5): 

INSERIMENTO DATI 
-PROVA DISPLAY- 
PREMI PULSANTE 
-SPEGNI DISPLAY- 

Se noi scriviamo: 

Idi x,testOI .d 

nel registro x verrà caricato l’indirizzo 40h. 

A questo punto vi sarà una routine che provvederà 
a portare i 32 caratteri del primo testo da visualiz¬ 
zare, pertanto sul display comparirà la scritta: 

INSERIMENTO DATI 
-PROVA DISPLAY- 

Siccome questo programma non prevede l’utilizzo 
di altri dati da caricare in Data Rom Window, i 64 
bytes inizialmente caricati sono ancora memoriz¬ 
zati in questa area, pertanto per far apparire sui di¬ 
splay il secondo testo: 

PREMI PULSANTE 
-SPEGNI DISPLAY- 


sarà sufficiente scrivere: 

Idi x,test02.d 

e, così facendo, nel registro x verrà caricato l’indi¬ 
rizzo di memoria della Data Rom Window corri¬ 
spondente al primo byte del secondo testo (eti¬ 
chetta test02) e cioè 60h. 

Quando il Compilatore assembla l’istruzione: 

Idi x,test02.d 

divide l’indirizzo di Program Space di test02 per 
64, poi al resto di questa divisione somma 64 e 
memorizza il risultato così ottenuto nell’istruzione 
stessa al posto dell’operando test02.d. 

Nel nostro caso, siccome test02 è stato definito 
all’indirizzo di Program Space A60h che corri¬ 
sponde al valore decimale 2656, avremo: 

2656 : 64 = 41,5 (rimane 0,5) 

64 x 0,5 = 32 sarebbe il resto 
resto 32 + 64 = 96 

che in esadecimale corrisponde a 60h. 

Se disponete di un software simulatore potrete ve¬ 
rificare nella finestra Disassembler, che la nostra 
istruzione: 

Idi x,test02.d 

dopo la compilazione (vedi fig.6) sarà diventata: 

Idi x,60h 

Quando verrà lanciato il programma assemblato, 
eseguendo questa istruzione nel registro x verrà 
caricato il valore 60h che corrisponde esattamen¬ 
te all’indirizzo di inizio del secondo testo (etichetta 

test02) in Data Rom Window e cioè: 

PREMI PULSANTE 
-SPEGNI DISPLAY- 
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Fig.5 Anche gli spazi sono considerati caratteri e vengono memorizzati. 
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Fig.6 Se controllate con il 
software la finestra del Di¬ 
sassembler, potrete nota¬ 
re che l’istruzione: 

Idi X,test02.d 
si sarà tramutata in: 

Idi X,60H 


e una successiva routine provvederà a visualizza¬ 
re sui display i 32 caratteri di questo testo. 

Questo vi fa capire l’importanza dell’utilizzo della 
sigla .d, che permette di caricare nel registro volu¬ 
to l’indirizzo di inizio di una stringa di dati memo¬ 
rizzati in Data Rom Window, quando al suo inter¬ 
no vi sono più stringhe indirizzabili. 

Nel prossimo esempio vi spieghiamo cosa succe¬ 
de se i dati definiti in Program Space non inizia¬ 
no esattamente con un indirizzo che non è esat¬ 
tamente un multiplo di 64. 

In questo esempio infatti abbiamo volutamente in¬ 
serito un errore nella definizione delle stringhe. 

Prendiamo sempre come esempio un programma 
che deve gestire un display alfanumerico compo¬ 
sto di 2 righe di 16 caratteri, che faccia apparire 
sulla prima riga del display la scritta: 


Nell’ultima istruzione del programma che termina 
all’indirizzo di Program Space C03h abbiamo de¬ 
finito le stringhe da visualizzare direttamente al by¬ 
te successivo senza utilizzare la direttiva .block 64- 
$%64 (vedi rivista 189): 


C04h 

testOI 

COAh 

test02 

CI Ah 

test03 

C26h 

test04 

C2Ch 

test05 

C3Ch 



.ascii “INIZIO” 

.ascii “INIZIALIZZAZIONE” 
.ascii “ATTIVAZIONE “ 

.ascii “BOX OK” 

.ascii “-ATTENDERE FASE-” 
.ascii “-DI SPEGNIMENTO-” 


Tralasciamo tutte le istruzioni del programma che 
non sono strettamente legate all’argomento che 
stiamo trattando ed arriviamo subito alla fase in cui 
il programma deve visualizzare sul display queste 
scritte. 


Innanzitutto il programma le carica in Data Rom 
Window con l’istruzione che già conoscete: 


INIZIO 


Idi drw,test01.w 


Supponiamo che in un secondo tempo questa scrit¬ 
ta scompaia e in sua sostituzione appaia: 

INIZIALIZZAZIONE 


Poiché, contrariamente agli esempi precedenti, te- 
stOI è stato definito volutamente ad un indirizzo 
C04h di Program Space che in decimale corri¬ 
sponde a 3.076, valore non divisibile per 64, avre¬ 
mo dei decimali: 


che poi anche questa scritta scompaia per essere 
sostituita dalla scritta: 

ATTIVAZIONE BOX 

che, dopo pochi secondi, anche la scritta sopra ri¬ 
portata scompaia per essere sostituita da: 


3.076 : 64 = 48,0625 

Quando il Compilatore assembla questa istruzione 
con .w, in pratica divide l’indirizzo di Program Spa¬ 
ce dell’etichetta per 64, perdendo il resto e me¬ 
morizza il risultato della divisione nell’istruzione 
stessa al posto dell’operando testOl.w. 


BOX OK 

Infine, che scompaia anche questa scritta per es¬ 
sere sostituita da una scritta che faccia apparire 
sulle due 2 righe del display: 

-ATTENDERE FASE- 
-Dl SPEGNIMENTO- 


Quindi al posto dell’operando testOl.w il Compila¬ 
tore sostituirà il valore 48 che in esadecimale cor¬ 
risponde a 30h. 

Se disponete di un software simulatore troverete 
che nella finestra Disassembler l’istruzione: 

Idi drw,testOl.w 















sarà diventata: 

Idi drw,30h 

Una volta assemblato e lanciato il programma vie¬ 
ne eseguita questa istruzione e il risultato viene me¬ 
morizzato nel Data Window Register. 

Il valore contenuto nel Data Window Register in¬ 
dicherà l’indirizzo (espresso in blocchi di 64 bytes) 
della stringa di dati che verrà così caricata in Da¬ 
ta Rom Window. 

Il microprocessore riconosce che il registro drw de¬ 
finito alla locazione di memoria C9h è il Data Win¬ 
dow Register, quindi carica in Data Rom Window 
64 bytes del nostro testo a partire dal 48° blocco 

(di 64 bytes l’uno) di Program Space. 

Se prendiamo il valore 48 contenuto nel Data Win¬ 
dow Register e lo moltiplichiamo per 64 otterre¬ 
mo: 

48 x 64 = 3072 

Espresso in esadecimale 3072 vale COOh. 

Perciò come risultato finale l’istruzione: 

Idi drw,testOI .w 

caricherà in Data Rom Window, 64 bytes di dati 
definiti in Program Space a partire dall’indirizzo 
COOh, cioè 4 bytes prima e non da C04h come ri¬ 
chiesto. 

Eseguendo una simulazione di questo programma 
nella finestra di Data Rom Window (vedi fig.7), ve¬ 
drete nella parte di sinistra le locazioni di memo¬ 
ria e il contenuto espresso in esadecimale, mentre 
nella parte destra la relativa decodifica in caratte¬ 
ri ASCII. 

Negli indirizzi da 40h a 43h saranno entrati dei va¬ 
lori che nulla hanno a che vedere con le nostre 


stringhe: di conseguenza perderemo dei dati ed in¬ 
fatti noteremo che l’ultima stringa riporterà solo: 

ENDERE FASE —DI 

quindi verrà perso SPEGNIMENTO-. 

La stringa INIZIO anche se parte da 44h anziché 
da 40h riusciremo sempre a visualizzarla. 

Quindi quando digiteremo l’istruzione con .d: 

Idi x,test01.d 

il Compilatore assemblerà questa istruzione divi¬ 
dendo l’indirizzo di Program Space di testOI per 
64, poi preleverà il resto di questa divisione, som¬ 
merà a questo resto il valore decimale 64 e lo me¬ 
morizzerà nell’istruzione stessa al posto dell’ope¬ 
rando testOl.d. 

Nel nostro caso, poiché testOI è stato definito all’in¬ 
dirizzo di Program Space C04h che corrisponde 
al valore decimale 3076, avremo: 

3076 : 64 = 48,0625 (rimane 0,0625) 

64 x 0,0625 = 4 (che sarebbe il resto) 
resto 4 + 64 = 68 

che in esadecimale corrisponde a 44h. 

Nota = L’esempio dei resti in tutte le operazioni 
che abbiamo riportato sono quelli che ci ritrovere¬ 
mo usando una normale calcolatrice tascabile. 

Se disponete di software simulatore potrete nota¬ 
re che nella finestra Disassembler (vedi fig.8) la 
nostra istruzione: 

Idi x,testOl.d 

si sarà convertita in: 

Idi x,44h 



Fig.7 Sulla sinistra della finestra Data troverete la decodifica esadecimale del nostro te¬ 
sto e sulla destra la decodifica ASCII (49 = 1, 4E = N, 5A = Z, 4F = O). 
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880 17 0F 
882 OD C9 29 
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88C 3F 86 
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Idi dru,29H 


Idi X,44H 


cp A,storex 
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cp A,verfin 
Idi campo,0OH 
Idi campo,0IH 


■ 




Fig.8 Se controllate con il 
software la finestra del Di¬ 
sassembler, potrete nota¬ 
re che l’istruzione: 

Idi X,test01 .d 
si sarà tramutata in: 

Idi X,44H 


Quando verrà lanciato il programma assemblato, 
nel registro x verrà caricato il valore 44h. 

Se guardate la fig.7 potrete constatare che in Da¬ 
ta Rom Window l’indirizzo 44h corrisponde in ef¬ 
fetti al primo byte della stringa “INIZIO”. 

A questo punto occorre soltanto inserire una routi¬ 
ne ciclica che provvederà a portare i 6 caratteri del 
testo INIZIO sul display. 

Successivamente il programma deve visualizzare 
la scritta: 

INIZIALIZZAZIONE 

e se guardate in fig.7 vedrete che anche la stringa 
“INIZIALIZZAZIONE” è completa e quindi per vi¬ 
sualizzarla si dovrà digitare: 

Idi x,test02.d 

Quando il Compilatore assembla questa istruzio¬ 
ne, divide l’indirizzo di Program Space di test02 
per 64, preleva il resto di questa divisione, somma 
a questo resto il valore decimale 64 e lo memoriz¬ 
za nell’istruzione al posto dell’operando test02.d. 

Nel nostro caso, poiché test02 è stato definito all’in¬ 
dirizzo di Program Space COAh che corrisponde 
al valore decimale 3082, avremo: 

3082 : 64 = 48,15625 (rimane 0,15625) 

64 x 0,15625 = 10 (che sarebbe il resto) 
resto 10 + 64 = 74 

che corrisponde al numero esadecimale 4Ah. 

Se controllate la finestra Disassembler, noterete 
che l’istruzione: 

Idi x,test02.d 


Quando verrà lanciato il programma assemblato, 
l’istruzione soprariportata caricherà nel registro x il 
valore 4Ah. 

Se guardate in fig.7 potrete constatare che in Data 
Rom Window l’indirizzo 4Ah corrisponde in effetti 
al primo byte della stringa “INIZIALIZZAZIONE”. 

A questo punto dovremo creare una routine ciclica 
che provveda a portare i 16 caratteri del testo INI- 
ZIALIZZAZIONE sul display. 

Proseguendo, dopo un certo tempo il programma 
deve visualizzare la scritta: 

ATTIVAZIONE BOX 

Anche questa stringa ATTIVAZIONE BOX è com¬ 
pleta in Data Rom Window, perciò alla istruzione: 

Idi x,test03.d 

quando il Compilatore assembla questa istruzione 
divide l’indirizzo di Program Space di test03 per 
64, preleva il resto di questa divisione, somma a 
questo resto il valore decimale 64 e lo memorizza 
nell’istruzione al posto dell’operando test03.d. 

Nel nostro caso, poiché test03 è stato definito all’in¬ 
dirizzo di Program Space CI Ah che corrisponde 
al valore decimale 3098, avremo: 

3098 : 64 = 48,40625 (rimane 0,40625) 

64 x 0,40625 = 26 (che sarebbe il resto) 
resto 26 + 64 = 90 

che in esadecimale corrisponde al numero 5Ah. 

Osservando la finestra Disassembler noterete che 
l’istruzione: 

Idi x,test03.d 


sarà diventata: 

Idi x,4Ah 


sarà diventata: 

Idi x,5Ah 

















Quando verrà lanciato il programma assemblato l’i¬ 
struzione soprariportata caricherà nel registro x il 
valore 5Ah. 

Se guardate in fig.7 potrete constatare che in Da¬ 
ta Rom Window l’indirizzo 5Ah corrisponde in ef¬ 
fetti al primo byte della stringa “ATTIVAZIONE 
BOX”. 

A questo punto andrà solo inserita una routine ci¬ 
clica che provvederà a portare i 16 caratteri del te¬ 
sto ATTIVAZIONE BOX sul display. 

Lo stesso dicasi per la scritta: 

BOX OK 

per visualizzare la quale occorre solo digitare: 

Idi x,test04.d 

A questo punto il programma per terminare deve 
visualizzare sulle 2 righe del display: 

-ATTENDERE FASE- 
-Dl SPEGNIMENTO- 


ma, se ricordate (vedi fig.7), in Data Rom Window 
risulta caricata soltanto: 

-ATTENDERE FASE—DI 

perchè le stringhe dichiarate sono più lunghe di 64 
bytes, infatti in totale abbiamo 72 bytes. 

Poiché la prima stringa l’abbiamo definita per er¬ 
rore all’indirizzo C04h anziché COOh, osservando 
la fig.9 potrete capire perchè si perde l’ultima pa¬ 
rola: 

SPEGNIMENTO 

A questo punto per visualizzare la scritta comple¬ 
ta verrebbe logico pensare che risulti sufficiente ri¬ 
caricare la frase completa: 

“-ATTENDERE FASE-” 

“-DI SPEGNIMENTO-” 

in Data Rom Window con l’istruzione: 

Idi drw,test05.w 


)b — C04h —^ + TEST01 

□□□□UHM 

npjODBDD 

-srìinnnnnn 


TEST02 


TEST03 


□BODDDDO* 

-annoili no 

□■□□BQBD 

BOBBBBlì? 


TEST04 


TEST05 


C40h —^ 

BBBBDDiB 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

Fig.9 Nella Data Rom Window non si pos¬ 
sono inserire più di 64 bytes. Tutti i bytes 
in eccesso verranno persi. 


)h — C04I —+ TEST01 

□□□□Afona 

□pi !□□□□□ 

testo •|§fj q q q q □ o 


TESTO 


BBGiniDB. 

^rnnnnHnn 


TEST04 


□ □ □ □ □ urjrr- block 64 
□□□□□□□□ 


C40h 


—^ ^ TESTO 



nnnnnnni 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

Fig.10 Per non perdere i bytes eccedenti do¬ 
po il primo blocco si deve inserire la di¬ 
rettiva .block 64-$%64. 





e poi indirizzarla nel registro x scrivendo: 

Idi x,test05.d 


Infatti, come già saprete, con l’istruzione: 


e successivamente visualizzarla con una routine 
sul nostro display. 


Se eseguirete queste due operazioni commettere¬ 
ste il più grossolano degli errori. 


□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

TEST02 


TEST01 



TESTO 



)h —^ TESTO 

□□□□□□□□ 

□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
8013 —) s TE ST05 

□□□□□□□ 


□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 


Fig.11 Se Tindirizzo di Program Space di te- 
stOI si dovesse spostare, noi perderemmo 
tutte le parole che fuoriescono dall’area del 
primo blocco da 64. 


Idi drw,test05.w 

Tindirizzo di Program Space dell’etichetta test05 
viene diviso per 64. Il risultato di questa divisione 
viene poi memorizzato nel Data Window Register 
(drw) perdendo l’eventuale resto. 


)l —^ ^ .block 64 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 



TEST04 - an DDDDDO 

BlDQiliQ 

.block 64 

□□□□□□□□ 
□□□□□□□□ 
)h —| * TEST05 

□□□□□□□ 

□□BDUBBB 

BDBIBDBB 

DDE3BODOB 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 


Fig.12 Inserendo.block 64-$%64 prima di te- 
stOI, questo testo si posizionerà sul 1 ° by¬ 
te di memoria del secondo blocco da 64 e 
test05 sul terzo blocco da 64. 




Nel nostro caso test05 è stato definito all’indirizzo 
di Program Space C2Ch che, convertito in deci¬ 
male, corrisponde al numero 3116. 

Se divideremo questo numero per 64 otterremo: 

3116 : 64 = 48,6875 (rimane 0,6875) 

64 x 0,6875 = 44 (che sarebbe il resto) 

Poiché in questo caso perdiamo il resto 44, ci ri¬ 
mane il solo numero 48 che verrà caricato nel Da¬ 
ta Window Register. 

Se moltiplichiamo 48 per 64 bytes otterremo sem¬ 
pre il numero: 

48 x 64 = 3072 

che corrisponde al valore esadecimale COOh, quin¬ 
di come risultato finale l’istruzione: 


In pratica, quando il programma sarà Compilato in 
Assembler, la direttiva: 

.block 64 - $%64 

definirà un’area di 20 bytes vuota a partire dalla 
locazione di Program Space C2Ch così che la suc¬ 
cessiva definizione: 

test05 .ascii “-ATTENDERE FASE-” 

.ascii “-DI SPEGNIMENTO-” 

inizi dalla locazione di memoria Program Space 
C40h corrispondente al valore decimale 3136. 

A questo punto l’istruzione: 

Idi drw,test05.w 


Idi drw,test05.w 


caricherà in Data Rom Window il testo completo: 


caricherà in Data Rom Window, 64 bytes di dati 
definiti in Program Space, a partire dall’indirizzo 
COOh; pertanto ci ritroveremo sempre nella condi¬ 
zione di fig.7, cioè con la frase incompleta. 

Per ovviare a questo inconveniente dovremo inse¬ 
rire la direttiva: 

.block 64 - $%64 

come qui sotto riportato: 

.block 64 - $%64 

test05 .ascii “-ATTENDERE FASE-” 

.ascii “-DI SPEGNIMENTO-” 


-ATTENDERE FASE- 
-Dl SPEGNIMENTO- 

Per poterla caricare in un registro dovremo sem¬ 
plicemente scrivere: 

Idi x,test05.d 

Per poter trasferire questa frase sul display dovre¬ 
mo utilizzare una routine ciclica. 

Con la soluzione soprariportata non pensate di a- 
ver risolto il problema, purtroppo è ancora presen¬ 
te un errore. 


quindi avremo: 

testOI .ascii “INIZIO” 
test02 .ascii “INIZIALIZZAZIONE” 
test03 .ascii “ATTIVAZIONE “ 
test04 .ascii “BOX OK” 

.block 64 - $%64 

test05 .ascii “-ATTENDERE FASE-” 

.ascii “-DI SPEGNIMENTO-” 

Nella rivista N.189 abbiamo spiegato la funzione 
completa di .block 64 - $%64. 

Dal punto in cui viene definito .block 64 - $%64 il 
Compilatore calcola quanti bytes deve lasciare li¬ 
beri per posizionare l’inizio della stringa test05 sul 
primo byte del blocco successivo di 64 bytes co¬ 
me è possibile vedere in fig.10. 


Come potete vedere in fig.10 la stringa testOI non 
inizia dalla locazione COOh e per questo motivo la 
stringa test04 termina alla locazione C2Ch. 
Avendo inserito in questo punto .block 64 - $%64 
obbligheremo test05 ad iniziare dalla locazione 
C40H. 

Se eseguendo dei test ci trovassimo costretti a in¬ 
serire o togliere nel programma delle istruzioni, è 
ovvio che l’indirizzo di Program Space delle no¬ 
stre stringhe verrebbe automaticamente variato e 
potremmo così correre il rischio di non caricare in 
Data Rom Window tutto il nostro testo. 

Ammettiamo che in fase di controllo abbiamo do¬ 
vuto inserire delle nuove istruzioni aN’interno del 
programma e che, in questo modo, testOI passi da 
C04h all’indirizzo C21h (vedi fig.11). 


Se ora caricassimo in Data Rom Window la strin¬ 
ga testOI perderemmo le ultime lettere: 

NE -BOX -OK 

perchè fuoriescono dall’area 64 bytes di Data Rom 
Window. 

Non avremo invece nessun problema per test05 
perchè ce lo ritroveremo nella successiva area di 
memoria C80h (vedi fig.11). 

Per evitare questo errore è sufficiente inserire 
.block 64 - $%64 prima della stringa testOI come 
qui sottoriportato: 

.block 64 - $%64 
testOI .ascii “INIZIO” 
test02 .ascii “INIZIALIZZAZIONE” 
test03 .ascii “ATTIVAZIONE “ 
test04 .ascii “BOX OK” 

.block 64 - $%64 

test05 .ascii “-ATTENDERE FASE-” 

.ascii “-DI SPEGNIMENTO-” 



Ih —n 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

Fig.13 Se la stringa di dati inizia esatta¬ 
mente da un indirizzo di memoria Program 
Space divisibile per 64 senza resto, non è 
necessario inserire .block 64-$%64. 


Non dovremo perciò più preoccuparci se durante il 
test del programma aggiungiamo o togliamo i- 
struzioni dal programma, perchè automaticamente 
.block 64-$%64 provvederà a calcolare l’area ne¬ 
cessaria per allineare le definizioni di dati al bloc¬ 
co ottimale (divisibile per 64) di Program Space 
come visibile in fig.12. 

Come visibile in fig.12 la stringa di testOI partirà 
sempre dal primo byte di memoria del secondo 
blocco da 64, che nel nostro esempio è C40h. 

Il successivo blocco di test05 inizierà dalla loca¬ 
zione di memoria C80h. 


Dopo questa spiegazione molti, per evitare di in¬ 
correre in uno degli errori sopracitati, abuseranno 
di questo .block 64 - $%64, ma in questo modo 
potrebbero sprecare inutilmente molti blocchi di 64 
bytes di Program Space. 


—n * .block 64 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 



Fig.14 Infatti, inserendo .block 64-$%64 in 
una locazione di memoria divisibile per 64 
senza resto, il testo viene posto nel blocco 
seguente sprecando l’area del primo. 




)\ —i ^ .block 64 

□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
□□□□□□□□ 
C80h —; 

□□□□□□□ 



9h —i block64 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

□□□□□□□□ 

DOOh 

□□□□ODDI 




Fig.15 In questo esempio non è stata usa¬ 
re la direttiva .ite ne ($%64) e per questo 
motivo il 1 ° e il 3° blocco sono vuoti. 


Questo spreco blocchi si verifica ogniqualvolta la 
direttiva .block 64 - $%64 viene inserita in una lo¬ 
cazione di memoria di Program Space perfetta¬ 
mente divisibile per 64 senza resto. 

Ammettiamo di avere una stringa di dati lunga e- 
sattamente 64 bytes (vedi fig.13) che inizia da 
C40h, cioè: 

necatOI .ascii “IMPOSTARE PARA” 

.ascii "METRI DI CONFIGLI” 

.ascii “RAZIONE E PROSEG” 

.ascii “UIRE CON IL TEST” 

Durante la stesura del programma, se non esegui¬ 
remo dei calcoli, non sapremo mai se questa strin¬ 
ga inizia esattamente da C40h; pertanto se, per e- 
vitare errori, prima di questa stringa inseriamo 
,block64-$%64, il Compilatore provvederà a collo¬ 
care questa stringa all’Indirizzo C80h sprecando i 
precedenti 64 bytes come illustrato in fig.14. 

Poiché di questi casi se ne potrebbero presentare 
diversi, sprecheremo inutilmente molti blocchi di 
memoria (vedi fig.15). 

Per ovviare a questo inconveniente c’è una sem¬ 
plice soluzione che non tutti conoscono, che utiliz¬ 
za la direttiva: 

.ite che significa Compila solo se... 

Questa direttiva ci permette di compilare parti di 
programma o di inserire moduli a scelta solo se 
sono Vere (o False) le condizioni specificate. 

Pertanto se nel programma, prima delle definizio¬ 
ni di dati in Program Space inseriremo: 

.ite ne ($%64) 

.block 64 - $%64 

.ende 

necatOI .ascii “IMPOSTARE I PARA” 

.ascii “METRI DI CONFIGU” 

.ascii “RAZIONE E PROSEG” 

.ascii “UIRE CON IL TEST” 

otterremo che .block 64 - $%64 sarà Compilata in 
assembler solo se non si trova in una locazione di 
Program Space divisibile esattamente per 64. 

Quindi con le tre istruzioni riportate prima della 
stringa necatOI, il Compilatore compila l’istruzione 
,block64-$%64 solo se il risultato della Espres¬ 
sione ($%64) non è uguale a zero (ne). 

Facciamo presente che la direttiva .ende deve es¬ 
sere sempre inserita come istruzione finale quan¬ 
do si usa .ifc. 

Nella rivista N.189 abbiamo spiegato cosa sono le 
Espressioni e come procedere al loro svolgimento. 



LE DIRETTIVE dell’assembler ST6 


Poiché in nessun manuale è spiegato in modo comprensibile come usare 
correttamente le Direttive dell’Assembler dell’ST6, cercheremo di risolvere 
questo problema spiegandovi anche tutti quei piccoli segreti di cui pochi 
sono al corrente. In questo articolo, tutto sulle direttive .ASCII .ASCIZ .DEF. 


Già saprete che la memoria dell’ST6 è suddivisa in: 

Memoria Ram = definita anche Data Space 
Memoria Rom = definita anche Program Space 

La Memoria Ram è riscrivibile, quindi si utilizza 
nei programmi come memoria dinamica per me¬ 
morizzare risultati di calcoli o di dati variabili in ap¬ 
posite celle e, poiché è di tipo volatile, quando vie¬ 
ne tolta tensione al microprocessore questi dati 
vengono automaticamente cancellati. 

La Memoria Rom (Read only memory) si utilizza 
per inserire le istruzioni del programma, quindi u- 
na volta che queste risultano memorizzate nel mi¬ 
croprocessore non si possono più modificare nè 
cancellare. 

LA DIRETTIVA chiamata .ASCII 

La direttiva .ascii serve per definire dei dati nella 
Program Space che è l’area Rom riservata alle i- 
struzioni del programma. 


In pratica questa direttiva viene utilizzata per defi¬ 
nire nella Program Space delle stringhe di carat¬ 
teri alfanumerici e per associare eventuali eti¬ 
chette in quei programmi che generano messaggi 
o scritte di vario genere su video o su stampa. 

Ogni tentativo di utilizzarla per definire dati nella 
Data Space darà un errore di compilazione. 

La lunghezza in bytes è definita dal numero di ca¬ 
ratteri ascii inseriti fra le virgolette. 

Chiaramente queste stringhe così definite non so¬ 
no modificabili durante il corso del programma per¬ 
chè definite nella memoria ROM. 

Per poterle utilizzare dovremo caricarle in Data 
Rom Window con le stesse modalità e gli stessi 
accorgimenti già spiegati nella rivista N.190 nel pa¬ 
ragrafo riguardante la direttiva .w_on. 

Anche per la loro definizione, in fase di stesura del 
programma, bisognerà attenersi a quanto riportato 










































































nella parte riguardante la direttiva .block sempre 
descritta nella rivista N.190. 

Il suo utilizzo permette di usufruire di una notevo¬ 
le quantità di messaggi in Program Space senza 
riempire inutilmente l’area di Data Space che, di¬ 
sponendo di soli 60 bytes, potremo sfruttare per 
delle Variabili tramite la direttiva .def. 

Il formato logico della direttiva .ascii è il seguente: 

[etichetta] .ascii “stringa” 

[etichetta] = Nome dell’etichetta che si vuole as¬ 
sociare al primo byte della stringa. Questo nome 
è opzionale quindi può essere anche omesso. 

“stringa” = In tale stringa si inseriscono i caratte¬ 
ri alfanumerici che si vogliono definire in Program 
Space, racchiudendoli sempre fra virgolette. 

Per rendere più chiaro quanto detto finora vi pro¬ 
poniamo questo semplice esempio: 

scrittal .ascii “/*-INIZIO-*\” 

.ascii “/*-Premi-P1 > per uscire” 

La prima stringa di caratteri /*-INIZIO-*\ è compo¬ 
sta da 12 bytes, mentre la seconda stringa di ca¬ 
ratteri, cioè /*-Premi-P1 > per uscire, è composta 
da 24 bytes. Facciamo presente che gli spazi so¬ 
no anche questi dei caratteri alfanumerici, quindi 
vanno conteggiati. 

In fase di Compilazione l’Assembler definisce nel¬ 
la Program Space la seguente stringa: 

/*-INIZIO-*V*-Premi PI > per uscire 

per un totale di 12 + 24 = 36 bytes 

ed associa all’indirizzo di Program Space del pri¬ 
mo byte della stringa l’etichetta scrittal. 

LA DIRETTIVA chiamata .ASCIZ 

Anche questa direttiva viene utilizzata per definire 
in Program Space delle stringhe di caratteri alfa- 
numerici ed associarvi eventuali etichette. 

Con la direttiva .ASCIZ, il compilatore inserisce in 
coda ad ogni singola stringa 1 byte contenente il 
valore OOh che è un carattere non editabile (nuli). 

La lunghezza in bytes di questa stringa è definita 
dal numero di caratteri alfanumerici inseriti fra le 
virgolette, addizionando a questi 1 byte. 


Perciò se scriviamo: 

scrittal .asciz “/*-INIZIO-*\” 

.asciz “/*-Premi-P1 > per uscire” 

la prima stringa risulterà composta da: 

12 bytes + 1=13 

mentre la seconda stringa sarà composta da: 

24 bytes +1 = 25 

In fase di compilazione verrà definita nella Pro¬ 
gram Space la seguente stringa: 

/*-INIZIO-*\(null)/*-Premi PI > per uscire (nuli) 

dove (nuli) rappresenta 1 byte contenente OOh che 
non è rappresentabile in formato ASCII, pertanto 
questa stringa risulterà lunga: 

12 + 1 + 24 + 1 = 38 bytes 

Quindi per definire delle stringhe di dati in Pro¬ 
gram Space ogni programmatore potrà scegliere 
indifferentemente sia .ascii che .asciz. 

Scegliendo .ascii il compilatore Assembler defini¬ 
sce nella Program Space la seguente stringa: 

/*-INIZIO-*V*-Premi TI > per uscire 

Se, per esempio, si desidera far apparire sul mo¬ 
nitor la parola della prima stringa /*-INIZIO-*\ com¬ 
posta di 12 caratteri, dovremo realizzare una rou¬ 
tine che conti esattamente i 12 caratteri da invia¬ 
re sul video, altrimenti si correrà il rischio di veder 
apparire anche caratteri della seconda stringa. 

Se si utilizza .asciz, il compilatore Assembler de¬ 
finisce nella Program Space la seguente stringa: 

/*-INIZIO-*\(null)/*-Premi PI > per uscire (nuli) 

e in questo caso non è necessario realizzare una 
routine che conti i caratteri, ma una diversa rou¬ 
tine che provveda ad inviare sul video tutti i carat¬ 
teri della stringa precisando che si deve fermare 
quando incontra OOh = nuli. 

In pratica questo OOh equivale ad un comando di 
stop lettura. 


LA DIRETTIVA chiamata .DEF 

La direttiva .def viene utilizzata per definire delle 
etichette associandole ad una cella di memoria di 
Data Space il cui indirizzo, come già saprete, è 
contenuto nell’operando indiriz. 


Il formato logico della direttiva .def è il seguente: 

[etich] .def indiriz,[R-mask],[W-ask],[value],[M] 

Nota = Gli operandi posti fra parentesi quadra so¬ 
no opzionali e possono essere omessi, togliendo 
anche le parentesi quadre. Inserite tutte le virgole 
come visibile nell’esempio. 

[etich] = nome della variabile che si vuole asso¬ 
ciare all’indirizzo di memoria. 

indir, = è l’indirizzo della cella di memoria Data 
Space. Questo valore può essere in Binario, De¬ 
cimale, Esadecimale o una Espressione. 

[R-mask] = utilizzando questo operando potremo 
definire quale degli 8 bits della variabile può risul¬ 
tare leggibile (R sta per READ = leggi). 

Se ad esempio scriviamo: 

pippo .def 08Dh,00100000b, 

sapremo già che la variabile pippo risulta colloca¬ 
ta nella locazione di Program Space 08Dh e che 
l’operando che segue, cioè OOlOOOOOb, è R-mask. 

Di questa variabile risulta leggibile il solo 5° bit per¬ 
chè settato a 1 (vi ricordiamo che i bit si leggono 
da destra verso sinistra 7-6-5-4-3-2-1 -0), mentre gli 
altri non risultano leggibili perchè settati a 0. 

Perchè tutti gli 8 bit risultino leggibili occorre o- 
mettere R-mask e ciò si ottiene scrivendo sempli¬ 
cemente: 

pippo .def 08Dh 

[W-mask] = utilizzando questo operando potremo 
definire quali degli 8 bits della variabile possono ri¬ 
sultare scrivibili (W sta per WRITE = scrivi). 

Se ad esempio scriviamo: 

pippo .def 08Dh,00100000b,1 OOOOOOOb 

sapremo già che la variabile pippo risulta colloca¬ 
ta nella locazione di Program Space 08Dh e che 
l’operando OOlOOOOOb è R-mask e quello che se¬ 
gue, cioè 10OOOOOOb è W-mask. 

Di questa variabile risulta scrivibile solo il 7° bit per¬ 
chè settato a 1 (bit di sinistra), mentre gli altri non 
risultano scrivibili perchè settati a 0. 

Se nell’istruzione vogliamo omettere R-mask ed u- 
tilizzare solo W-mask dovremo riportare due vir¬ 


golette in sostituzione di R-mask come indicato in 
questo esempio: 

pippo .def 08Dh„1 OOOOOOOb 

[value] = questo operando non risulta utilizzabile, 
quindi l’istruzione che abbiamo riportato in prece¬ 
denza, cioè: 

[etich] .def indiriz,[R-mask],[W-ask],[value],[M] 

la potremo semplificare omettendo value, scriven¬ 
do quindi soltanto: 

[etich] .def indiriz,[R-mask],[W-ask],[M] 

[M] = questo operando (potremo anche scriverlo in 
minuscolo), se inserito, mette un marker nella va¬ 
riabile [etich] nel file .DSD (vedi fig.1). 

Questo marker ci sarà utile in fase di Debug, per¬ 
chè potremo automaticamente vedere su video, u- 
tilizzando ovviamente un Simulatore, tutte le va¬ 
riabili a cui è stato associato appunto un marker: 
ciò ci consentirà di controllarne il valore in tempo 
reale (vedi fig.2). 



Dopo avervi spiegato il formato della direttiva .def 
ed il significato dei suoi operandi dovremo chiarire 
che cosa s’intende per bit leggibili e bit scrivibi¬ 
li ed indicare tutti i vantaggi di R-mask e W-mask. 

Ad esempio se scriviamo questa istruzione: 

prova jrs 3,store,finepr 

il programma salterà (jrs) all’etichetta finepr solo 

se il bit 3 della variabile store è settato. 

In pratica l’istruzione jrs (jump relative set) deve 
quindi leggere lo stato del bit 3 e se, per ipotesi, 
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Fig.2 In fase di simulazione potrete vedere 
sul vostro monitor tutte le variabili con¬ 
trassegnate con il marker M, complete del 
loro contenuto. 

Ogni tipo di simulatore farà apparire sul mo¬ 
nitor una sua particolare videata. 


avessimo definito la variabile store come qui sot¬ 
to riportato: 


Se poi il programma che stiamo scrivendo è molto 
complesso, oppure richiama molti moduli o ma- 
cro, questo tipo di errore sul test o sul settaggio 
dei bits delle variabili sarà più frequente di quan¬ 
to si possa supporre. 

Ammettiamo per esempio di voler testare in una 
variabile i bits 1-4-6 con le istruzioni: 

jrs 1, status, flagl 

jrs 4, status, flag4 

jrs 6,status,flag6 

Se per errore scrivessimo come visibile in fig.4: 

jrs 1,status,flagl 

jrs 3, status,flag4 (errore) 

jrs 6,status,flag6 

quando il programma passerà sulla seconda riga 

dove è presente l’errore, non salterà mai sul flag4, 
quindi non usando R-mask perderemmo tempo 
prima di individuarlo. 

Usando R-mask subito apparirà sul video il nu¬ 
mero della riga dov’è presente l’errore (vedi ASM 
58) con indicato il tipo di errore = 113 (vedi fig.5). 

Vi sono comunque delle precise regole che dovre¬ 
mo osservare nel dichiarare R-mak e W-mask e 
per farvelo meglio comprendere vi proponiamo al¬ 
cuni esempi: 


store .def 08Dh,11110111b 

avremmo definito leggibili tutti i bit tranne il bit 3, 
perchè avremmo messo uno 0 anziché 1, quindi il 
compilatore segnalerà errore. 

Perchè il compilatore non segnali nessun errore 
dovremo rendere leggibile il bit 3 scrivendo: 

store .def 08Dh,00001 OOOb 

Utilizzando R-mask e dichiarando “leggibili” i soli 
bits che ci interessano di una variabile, sarà lo 
stesso compilatore a trovare l’errore che potrem¬ 
mo aver commesso involontariamente, facendo ap¬ 
parire sul video l’istruzione che ha tentato di leg¬ 
gere il bit che non doveva leggere. 

Lo stesso dicasi per W-mask quando si utilizzano 
le istruzioni che “scrivono” (set , res ,ldi ecc.) nei 
diversi bits. 

In questi casi il compilatore non assemblerà il pro¬ 
gramma, quindi durante la simulazione eviteremo 
di trovare delle condizioni logiche non desiderate 
sui piedini del microprocessore. 


1) Esempio 


storex 

.def 

084h,10001 OOOb,00001111 b,M 

prova 

jrs 

0,storex,finepr 


set 

1,storex 

finepr 

res 

7,storex 



Fig.3 In questa figura vi facciamo vedere 
come appariranno sul monitor le cinque ri¬ 
ghe delle istruzioni del 1 0 esempio . Come 
potete notare, a fianco di ogni istruzione ab¬ 
biamo riportato dopo il ; il numero della re¬ 
lativa riga. 
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Fig.4 Inserendo R-MASK nella 
variabile STATUS, se commet¬ 
terete un errore involontario 
(ad esempio jrs 3,status,flag4) 
il compilatore lo segnalerà im¬ 
mediatamente (vedi fig.5). 


Fig.5 Poiché abbiamo tentato 
di compilare la riga 58 che è 
errata, il compilatore subito ce 
lo segnalerà indicandoci an¬ 
che il tipo di errore = 113. 


: : \ ST6>ast6 -x -1 -s C:\ST6\TEST.ASM 

5T6 MAGRO-ASSEMBLER version 4.00 - August 1992 

rror C:\ST6\TEST.ASM 71: (113) no read-access rights to operane! 2 

rror C:\ST6\TEST.ASM 73: (114) no write-access rights to operane! 2 

xecution time: 0 second(s) 
l errors eìetectecì 
Jo otoject created 

: :\ST6> 

3 ress a hey to return... 


Fig.6 Nel 1 ° esempio solo la i- 
struzione 72 è corretta, men¬ 
tre le due istruzioni 71-73 che 
sono errate vengono subito 
segnalate dal compilatore. 


Con la prima istruzione: 

storex .def 084h,10001 OOOb,00001111b,M 

il compilatore associa la variabile storex alla cel¬ 
la di memoria 084h di Data Space e in più defini¬ 
sce nell’ R-mask leggibili i soli bits 3-7. 
Nuovamente facciamo presente che i bits si leg¬ 
gono da destra verso sinistra 7-6-5-4-3-2-1-0. 

Poi definisce scrivibili nel W-mask i bits 0-1-2-3. 

Inoltre nel file .DSD (generato in compilazione) al¬ 
la variabile storex viene associato un marker. 

La successiva istruzione: 


significa salta all’etichetta finepr se il bit 0 di sto¬ 
rex è settato. 

Poiché nel R-mask il bit 0 non è leggibile, sul vi¬ 
deo apparirà un messaggio di errore. 

La successiva istruzione: 

set 1, storex 

che significa metti a 1 il bit 1 di storex, viene cor¬ 
rettamente compilata perchè il bit 1 definito in W- 
mask è “scrivibile”. 

L’ultima istruzione: 

finepr res 7,storex 


0,storex,finepr significa metti a 0 il bit 7 di storex. 


prova jrs 














In questo caso il compilatore farà apparire un mes¬ 
saggio di errore (vedi fig.5) perchè il bit 7 di sto- 
rex definito nella W-mask non è “scrivibile” es¬ 
sendo presente 0. 

In presenza di questi errori dovremo ricontrollare 
tutto il programma per scoprire se l’istruzione uti¬ 
lizza un bit sbagliato oppure se sono sbagliati i 
bits inseriti in R-mask o W-mask. 


2) Esempio (vedi fig.7) 


a 

.def 

OFFh 

storex 

.def 

084h,OOOOOOOOb,00000111 b 

prova 

Idi 

storex,6 


Idi 

storex,32 


Idi 

a,32 


Id 

storex,a 


cp 

a,storex 


Spiegazione: 

Con la prima definizione: 

a .def OFFh 

abbiamo definito l’accumulatore “a”. 



Fig.7 In questa figura vi facciamo vedere 
come si presentano sul monitor le sette ri¬ 
ghe delle istruzioni del 2° esempio. Di fian¬ 
co ad ogni istruzione abbiamo riportato do¬ 
po il ; il numero di riga. 


Con la seconda istruzione: 

storex .def 084h,OOOOOOOOb,00000111b 

il compilatore associa la variabile storex alla cel¬ 
la di memoria 084h di Data Space e in più defini¬ 
sce non leggibili gli 8 bits della variabile R-mask e 
scrivibili nella variabile W-mask i soli bits 0-1-2. 

La successiva istruzione: 

prova Idi storex,6 


significa carica nella variabile storex il valore de¬ 
cimale 6. 

Poiché si sa che 6 equivale a 000001 lOb (vedi a 
pag.381 del nostro volume Handbook), quando 
questo numero viene caricato nella variabile sto¬ 
rex si riesce a modificare lo stato dei tre bits 0-1- 
2 perchè in W-mask li abbiamo configurati scrivi¬ 
bili, pertanto questa istruzione viene correttamen¬ 
te compilata. 

La quarta istruzione: 

Idi storex,32 

significa carica nella variabile storex il valore de¬ 
cimale 32. 

Poiché si sa che 32 equivale a OOlOOOOOb (vedi 
sempre pag.381 del volume Handbook), quando 
viene caricato nella variabile storex non riuscirà a 
modificare lo stato del quinto bit, perchè questo in 
W-mask non è stato configurato scrivibile. 

Infatti su questo bit è presente uno 0 e non un 1. 
In questo caso verrà subito segnalato un errore di 
compilazione (vedi ASM 75 in fig.8). 

La quinta istruzione: 

Idi a,32 

significa carica nell’accumulatore “a” il valore 32. 

Questa istruzione viene correttamente compilata 
perchè nell’accumulatore “a” non abbiamo definito 
nè R-mask nè W-mask, comunque consigliamo di 
non utilizzarle mai nell’accumulatore perchè po¬ 
trebbero bloccare qualche altra funzione. 

La sesta istruzione: 

Id storex,a 

significa carica nella variabile storex il valore con¬ 
tenuto nell’accumulatore “a” che, nel nostro esem¬ 
pio, corrisponde al numero 32. 

Questa istruzione verrà compilata anche se sap¬ 
piamo, per averlo spiegato nella quarta istruzione, 
che non è possibile caricare il valore 32 in storex 
perchè in W-mask sono stati configurati scrivibili 
i soli bits 0-1-2. 

Il compilatore non può segnalare questo errore 
perchè, quando compila, non è in grado di con¬ 
trollare il contenuto nell’accumulatore “a”. 

Infatti per il compilatore è sufficiente che risulti scri¬ 
vibile anche uno solo degli 8 bits di W-mask di 
storex per ritenere questa istruzione corretta, quin- 








di quando si usa una istruzione con due variabili, 
nel nostro esempio “storex” e “a”, occorre sempre 
confrontare il valore contenuto nell’accumulatore 
“a” con i bits della W-mask della variabile storex 
durante la stesura del programma. 

La settima istruzione: 


Invece il compilatore non segnalerà nessun erro¬ 
re in cp a,storex perchè, non riuscendo a control¬ 
lare il contenuto nell’accumulatore “a”, è sufficien¬ 
te che un qualsiasi bits di storex riportato nel R- 
mask risulti leggibile per considerare l’istruzione 
valida. 


cp a,storex 


3) Esempio 


significa confronta il valore di “a” con il valore di 

storex. 

Questa istruzione ci segnalerà errore (vedi ASM 
78 in fig.8), perchè per eseguire un confronto fra i 
due valori l’istruzione cp deve leggerli, ma poiché 
in R-mask di storex è riportato OOOOOOOOb, nes¬ 
suno dei suoi bits è leggibile. 

Come già vi abbiamo accennato, il numero binario 
di 32 è OOlOOOOOb, quindi giustamente potreste pen¬ 
sare che si possa evitare l’errore rendendo leggibi¬ 
le il quinto bit della R-mask di storex. Purtroppo 
se ci sbagliamo e rendiamo leggibile il quarto bit o 
un qualsiasi altro bit, il compilatore non segnalerà 
piu’ nessun errore perchè, non essendo in grado 
di controllare il contenuto nell’accumulatore “a”, è 
sufficiente che un qualsiasi bit di R-mask risulti leg¬ 
gibile perchè esso ritenga valida l’istruzione. 

Se ne volete una conferma inserite le istruzioni di 
questo nostro esempio in un qualsiasi vostro pro¬ 
gramma di prova, poi andate a modificare la R.ma- 

sk di storex da: 

storex .def 084, OOOOOOOOb, 00000111 b 

in una delle due istruzioni qui sotto riportate: 

storex .def 084,IlOOOOOOb, 00000111b 
storex .def 084,00000011 b, 00000111 b 


Se vogliamo rendere leggibili tutti i bits di R-mask 
anziché scrivere llllllllb potremo mettere due 
sole virgole come qui sotto riportato: 

storex .def 084h, ,00001111b 

oppure inserire Offh tra le due virgole: 

storex .def 084h,Offh,00001111b 

Se vogliamo rendere leggibili e scrivibili tutti i bits 
di una variabile mask dovremo semplicemente 
scrivere: 

storex .def 084h 


4) Esempio 


storex 

.def 

campo 

.def 

verfin 

.def 

valfix 

.set 

inizio 

cp 


cp 


cp 


clr 


Idi 


Idi 


084h,Offh,00001111b 

storex+1, Offh,0001 OOOOb 

campo+1,m 

storex+2 

a,storex 

a,campo 

a,verfin 

campo 

campo,valfix 

verfin,valfix 


La prima istruzione: 


In questo caso il compilatore dovrebbe segnalare 
un errore perchè nel primo esempio abbiamo de¬ 
finito leggibili i bits 7-6 e nel secondo esempio ab¬ 
biamo definito leggibili i bits 1-0, mentre nel nu¬ 
mero 32 dovrebbe risultare leggibile il solo bit 5. 


storex .def 084h,Offh,00001111b 

significa, associa la variabile storex alla cella di 
memoria 084h di Data Space e poiché abbiamo 
reso leggibili tutti i bits di R-mask con Offh, il com- 


C:\ST6>ast6 -x -1 -s C:\ST6\TEST.ASM 

ST6 MACRO-ASSEHBLER version 4.00 - August 1992 

Ercor C:\ST6\TEST.ASM 75 : (112) no write-access rights to operane! 1 
Error C:\ST6\TEST.ASH 78 : (113) no uead-access rights to operane! 2 
Execution time: 1 second(^) 

3 errors detected 
No object created 

C:\ST6> 


Fig.8 Nel 2°esempio solo le i- 
struzioni 73-74-76-77 sono 
corrette, mentre le 75-78 risul¬ 
tando errate verrano subito 
segnalate dal compilatore. 


Press a key 


return... 






pilatore non effettuerà nessun controllo di lettura, 
mentre effettuerà un controllo nella W-mask per¬ 
chè abbiamo definito scrivibili i soli bits 0-1-2 3. 

La seconda istruzione: 

campo .def storex+1, Offh,0001 OOOOb 

associa la variabile campo alla cella di memoria 
085h (ormai dovreste essere esperti nel decodifi¬ 
care l’espressione “storex + 1”) di Data Space. 
Tutti gli 8 bits della variabile R-mask sono leggi¬ 
bili mentre nella W-mask è scrivibile solo il bit 4. 
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storex 

. def 

0 8 4 h,0 f f h,0 Q OD111 lb 

campo 

. def 

storex + 1,Offh, □ 

OOlOOOOb 

verfin 

. def 

caitipo+lfiti 


valfix 

. set 

storex+2 







. org 

□ 80 Oh 

; 80 

inizio 

cp 

a, storex 

co 


cp 

a,campo 

; 82 


cp 

a,verfin 

; 83 


clr 

campo 

; 84 


Idi 

campo,valfix 

; 85 


Idi 

verfin,valfix 

; 8 6 


Fig.9 In questa figura vi facciamo vedere 
come si presentano sul monitor le dieci ri¬ 
ghe delle istruzioni del 4° esempio. Anche 
in questo caso accanto ad ogni istruzione 
abbiamo riportato dopo il ; il numero di ri¬ 
ga per ritrovarle più facilmente. 


La terza istruzione: 

verfin .def campo+1,m 

associa la variabile verfin alla cella di memoria 
086h ( “campo + 1”) e omette sia R-mask che W- 
mask, ma inserisce un marker alla variabile ver¬ 
fin. 

Per omettere R-mask e W-mask non è necessa¬ 
rio scrivere come molti potrebbero supporre: 

verfin .def campo+1,0ffh,0ffh,m 

Per la quarta istruzione: 

valfix .set storex+2 

come già vi abbiamo spiegato nel capitolo riguar¬ 
dante le Espressioni, la direttiva .set associa una 
etichetta ad un valore e non ad un indirizzo di Me¬ 
moria Data Space come avviene con .def. 


Nel nostro esempio all’etichetta valfix viene asso¬ 
ciato il valore 086h (storex+2). 

Le tre successive istruzioni: 

inizio cp a,storex 

cp a,campo 

cp a,verfin 

confrontano il valore contenuto nell’accumulatore a 
con i valori contenuti rispettivamente in storex, 
campo e verfin. 

In fase si compilazione non viene segnalato nes¬ 
sun errore, perchè tutte e tre le variabili sono sta¬ 
te dichiarate leggibili in R-mask. 

La successiva istruzione: 

clr campo 

che significa azzera il valore della variabile cam¬ 
po, viene normalmente compilata senza problemi 
e senza generare degli errori. 

La penultima istruzione: 

Idi campo,valfix 

significa carica nella variabile campo il valore as¬ 
sociato a valfix e non, come molti ritengono, il va¬ 
lore contenuto in valfix. 

Poiché il compilatore controlla il valore da caricare 
nella variabile campo, in fase di compilazione se¬ 
gnalerà un errore perchè nel nostro esempio val¬ 
fix vale 086h (il suo numero binario è 100001 lOb) 
e nella W-mask di campo abbiamo definito scrivi¬ 
bile il solo bit 4 e non i bits 1-2-7. 

L’ultima istruzione: 

Idi verfin,valfix 

significa carica nella variabile verfin il valore as¬ 
sociato a valfix e viene regolarmente compilata 
senza segnalare errori perchè in verfin non è sta¬ 
ta definita la W-mask, pertanto viene eseguita sen¬ 
za effettuare alcun controllo. 

CONTINUA 

Nella rivista precedente abbiamo preso in esame 
la direttiva .W_ON, in questo numero le direttive 
.ASCII - .ASCIZ - .DEF, mentre nelle riviste suc¬ 
cessive passeremo a considerare tutte le direttive 
mancanti. 










PROGRAMMATORE 


Molti softwaristi dopo aver acquistato i program¬ 
matori commerciali per la nuova famiglia di micro 
ST62/60 - ST62/65, pagandoli più di 650.000 lire, 
si sono accorti che oltre ad essere troppo compli¬ 
cati da utilizzare (qualcuno ha bruciato diversi mi¬ 
cro), presentano il difetto di non funzionare su tut¬ 
ti i computer, tra i quali anche il Pentium. 

Tutti i softwaristi, che hanno acquistato il nostro 
programmatore per micro ST62/10-15-20-25, sono 
rimasti a tal punto soddisfatti, da richiedercene u- 
no identico per questa nuova famiglia, che sia in 
grado di funzionare su tutti i tipi di computer IBM e 
compatibili, compreso ovviamente il Pentium. 

Prima di passare alla descrizione dello schema e- 
lettrico vogliamo svelare a coloro che usano qual¬ 
siasi tipo di programmatore, compresi i nostri, un 
piccolo segreto che, da quanto ci risulta, nessuno 
ha mai reso pubblico. 

Ormai tutti sanno che i computer hanno due por¬ 
te parallele denominate LPT1 - LPT2, ma nessu¬ 
no si è mai preoccupato di precisare che il pro¬ 
grammatore deve essere obbligatoriamente colle¬ 
gato sulla porta LPT1. 


Quindi se il vostro computer ha la stampante col¬ 
legata sulla porta LPT1, dovrete spostarla sulla 

porta LPT2. 

Lasciando infatti la stampante sulla porta LPT1 e 
collegando il programmatore sulla porta LPT2, po¬ 
treste non riuscire a farlo funzionare. 

A coloro che ci hanno chiesto se questa nuova fa¬ 
miglia di microprocessori sostituirà i precedenti 
ST6, assicuriamo che anche questi continueranno 
ad essere prodotti, ad esclusione del solo 
ST62E10 cancellabile. L’ST62T10 tipo OTP rima¬ 
ne invece in commercio. 

Ci è stato inoltre domandato che cosa ha in più 
questo nuova famiglia ST62/60 e ST62/65 rispetto 
alla precedente. Rispondiamo accennando veloce¬ 
mente alle novità di questi microprocessori: 

- Un banco di memoria RAM di 128 K, cioè il dop¬ 
pio dei precedenti ST6. 

- Un supplementare banco di 128 bytes di me¬ 
moria EEprom (si pronuncia E-quadroprom e la 
sigla sta per Electrically Erasable Programmable 
























Read Only Memory). Questa memoria è cancella¬ 
bile e riscrivibile elettricamente diverse migliaia di 
volte. Una volta scritti i dati nella EEprom, rimar¬ 
ranno memorizzati anche se toglieremo la tensio¬ 
ne di alimentazione; ovviamente riappariranno 
quando il micro verrà nuovamente alimentato. 

La EEprom permette di risolvere molti problemi. 
Ad esempio, noi stessi ci siamo serviti di questi 128 
bytes in più presenti nel micro ST62/T65, per te¬ 
nere in memoria le posizioni dei satelliti TV nel kit 
Box per posizionare le parabole TV (kit LX.1195) 
apparso sulla rivista N.177-178. 

- Una Interfaccia Seriale SPI (Synchronous Pe- 
ripheral Interface) in grado di trasmettere e riceve¬ 
re dei dati seriali. 

- Un Timer Autoreload autoricaricabile che serve 
anche per gestire la funzione PWM. 


- Un Timer identico ai precedenti micro ST6. 

- Una funzione PWM (Pulse Width Modulation), 
che ci permette di ottenere in uscita delle onde 
quadre con duty-cycle variabile, utilizzabili per ri¬ 
cavare delle tensioni variabili oppure delle forme 
d’onda sinusoidali o triangolari con l’impiego di po¬ 
chi componenti esterni. 

Nella Tabella N.1 riportiamo le caratteristiche più 
interessanti di questa nuova famiglia. 

Per programmare la nuova famiglia di micropro¬ 
cessori abbiamo progettato il programmatore si¬ 
glato LX.1325 (vedi fig.1), che risulta ben diverso 
dal precedente LX.1170. 

Il programmatore LX.1325 serve solo per i micro 
ST62/60-65 e poiché il procedimento di program- 


per MICRO ST62/60-65 


Sulla rivista N.172/173 vi abbiamo presentato un programmatore per i 
micro della famiglia ST62T10-T15-T20-T25 e ST62E15-E20-E25. Poiché 
da tempo è uscita la nuova famiglia ST62T60-T65 e ST62E60-E65, in mol¬ 
ti ci hanno richiesto un programmatore dalle prestazioni simili a quello 
già progettato, ma che programmi questi nuovi micro. 


Tabella N.1 


Micro tipo OTP ( NON CANCELLABILI ) 


sigla 

memoria 

memoria 

memoria 

piedini 

numero 

numero 

numero 

micro 

program. 

RAM 

EEPROM 

zoccolo 

Porte A 

Porte B 

Porte C 

ST62T60 

4 K 

128 bytes 

128 bytes 

20 

4 

6 

3 

ST62T65 

4 K 

128 bytes 

128 bytes 

28 

8 

8 

5 


Micro tipo EPROM ( CANCELLABILI con lampade ULTRAVIOLETTE ) 


sigla 

memoria 

memoria 

memoria 

piedini 

numero 

numero 

numero 

micro 

program. 

RAM 

EEPROM 

zoccolo 

Porte A 

Porte B 

Porte C 

ST62E60 

4 K 

128 bytes 

128 bytes 

20 

4 

6 

3 

ST62E65 

4 K 

128 bytes 

128 bytes 

28 

8 

8 

5 


In questa tabella sono riportate le caratteristiche più interessanti dei micro ST62. 



































mazione e il linguaggio assembler rimangono gli 
stessi che abbiamo iniziato a spiegare per gli 
ST62T10 eco., chi ha seguito i nostri precedenti ar¬ 
ticoli (abbiamo iniziato dalla rivista N.172) non in¬ 
contrerà nessuna difficoltà ad usarlo. 

Per questo motivo vi spiegheremo come dovete 
procedere per le sole funzioni supplementari, cioè 
Seriale, PWM ed EEprom. Se sarà il caso in un 
prossimo futuro vi prepareremo anche un valido 

software simulatore. 


SCHEMA ELETTRICO 

Per quel che concerne lo schema elettrico raffigu¬ 
rato in fig.2, vogliamo subito precisare che il 
CONN.1, visibile sul lato sinistro, è un connettore 
maschio a 25 poli, che deve essere collegato tra¬ 
mite un cavo parallelo alla porta parallela LPT1 
del vostro computer. 

Se acquistate i cavi paralleli in un supermercato 
accertatevi che i piedini 1 - 2 - 3 - 4 ecc. del ma¬ 
schio risultino collegati sui piedini 1 - 2 - 3 - 4 ecc. 
del connettore femmina, perché è piuttosto facile 
trovare cavi paralleli con le connessioni invertite. 

Come qualsiasi altro programmatore, anche il no¬ 
stro legge i dati contenuti nel micro e logicamente 
li scrive al suo interno prelevandoli dal computer. 
Per programmare i micro ST62/60-65 è necessa¬ 
rio un nuovo Software chiamato ST626xPG che è 
totalmente diverso da quello che fino ad oggi ave¬ 
te usato per i micro ST62/10-15-20-25. 

Poiché non tutti riusciranno a procurarsi questo 
nuovo software, abbiamo ritenuto opportuno for¬ 
nirvi assieme al kit anche il dischetto software. 

Come potete notare dalla fig.2, in questo pro¬ 
grammatore abbiamo inserito due zoccoli textool, 
uno da 28 piedini ed uno da 20, per il semplice 
motivo che i piedini di programmazione Vcc - Vpp 

- OSC.IN. - RESET - GND - PB2 - PB3 non fanno 
sempre capo agli stessi piedini nei due zoccoli. 

La tensione continua di circa 20 volt che prelevia¬ 
mo dall’alimentatore siglato LX.1170/B, passando 
attraverso il diodo DS1, raggiunge l’integrato IC2, 
che provvede a stabilizzarla sul valore di 5 volt. 
Questa tensione alimenta l’integrato IC1, un C/Mos 
tipo SN.74HC14 composto da 6 Inverter a trigger 
di Schmitt. 

La tensione di 20 volt raggiunge anche il termina¬ 
le Emettitore del transistor TRI , un PNP utilizzato 
come interruttore elettronico e come circuito di 
protezione. Grazie a questo transistor non dan- 


neggerete i micro se per errore li inserirete negli 
zoccoli textool in senso errato. 

Fino a quando il computer non invia al program¬ 
matore il comando di scrittura o lettura, sul piedi¬ 
no 2 (DO) del CONN.1 troviamo un livello logico 
1 che viene invertito da IC1/A. Poiché l’uscita di 
questo trigger è collegata al transistor NPN siglato 
TR2, sulla sua Base viene applicato un livello lo¬ 
gico 0. 

Con questo livello logico il transistor TR2 non con¬ 
duce e quindi non riesce a polarizzare la Base del 
transistor PNP siglato TRI . La tensione positiva dei 
20 volt applicata sul suo Emettitore non può dun¬ 
que fuoriuscire dal suo Collettore e, di conseguen¬ 
za, non raggiunge i due integrati stabilizzatori IC3 
ed IC4 che a loro volta non possono inviare al mi¬ 
cro, inserito in uno dei due zoccoli textool, nes¬ 
suna tensione di alimentazione. 

Solo quando abilitiamo il computer a leggere o scri¬ 
vere sul micro, sul piedino 2 (DO) del CONN.1 tro¬ 
viamo un livello logico 0, che porta in conduzio¬ 
ne il transistor TR2. Automaticamente questo prov¬ 
vede a polarizzare la Base del transistor TRI e co¬ 
sì la tensione positiva dei 20 volt applicata sul suo 
Emettitore fuoriesce dal suo Collettore e raggiun¬ 
ge i due integrati stabilizzatori IC3 ed IC4 che su¬ 
bito provvedono ad alimentare il micro inserito in 
uno dei due zoccoli textool. 

L’integrato stabilizzatore IC3 viene utilizzato per 
fornire una tensione di 5 volt stabilizzata sul pie¬ 
dino Vcc e, tramite il diodo schottky siglato DS5, 
una tensione di poco inferiore sul piedino Vpp. 

Prima di procedere alla programmazione del micro 
il computer testa tramite i comandi Blanck Check 
e Read se il micro non risulti già programmato op¬ 
pure se non sia vergine o difettoso e, se tutto ciò 
non bastasse, verifica che tutti i piedini siano inse¬ 
riti nello zoccolo ed anche che sia stato scelto il mi¬ 
cro giusto per il programma che si vuole memoriz¬ 
zare. 

Durante queste fasi di controllo l’inverter IC1/C 
provvede ad inviare sui piedini di RESET (piedino 
22 per gli ST62/65 e piedino 16 per gli ST62/60) u- 
na tensione di 5 volt. 

Sebbene l’integrato stabilizzatore IC4 sia da 5 volt, 
dà in uscita una tensione di 13,2 volt perché sul 
suo piedino M è collegato un diodo zener da 8,2 
volt (vedi DZ1): infatti 8,2 + 5 = 13,2 volt. 

La tensione di 13,2 volt circa raggiunge il solo pie¬ 
dino Vpp quando il transistor PNP siglato TR3 vie- 



ELENCO COMPONENTI LX.1325 


RI = 4,7 ohm 
R2 = 4.700 ohm 
R3 = 10.000 ohm 
R4 = 1.000 ohm 
R5 = 10.000 ohm 
R6 = 560 ohm 
R7 = 4.700 ohm 
R8 = 10.000 ohm 
R9 = 1.000 ohm 
RIO = 10.000 ohm 
RII = 1.000 ohm 
RI 2 = 1.000 ohm 
RI3 = 10.000 ohm 


RI4 = 1.000 ohm 
R15 = 10 ohm 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 22 mF elettrolitico 
C4 = 100.000 pF poliestere 
C5 = 100.000 pF poliestere 
C6 = 100.000 pF poliestere 
C7 = 100.000 pF poliestere 
C8 = 100.000 pF poliestere 
C9 = 100.000 pF poliestere 
DS1 = diodo tipo 1N.4007 
DS2 = diodo tipo 1N.4150 


DS3 = diodo tipo 1N.4150 
DS4 = diodo tipo 1N.4150 
DS5 = diodo schottky BAR.10 
DZ1 = zener 8,2 volt 1/2 watt 
TRI = PNP tipo BD.140 
TR2 = NPN tipo BC.547 
TR3 = PNP tipo BC.328 
TR4 = NPN tipo BC.547 
IC1 = C/Mos tipo 74HC14 
IC2 = UA.78L05 
IC3 = UA.78L05 
IC4 = UA.78L05 
CONN.1 = connettore 25 poli 





























































































ELENCO COMPONENTI LX.1170/B 




R9 = 1.500 ohm 
C7 = 1.000 mF elettrolitico 
DL1 = diodo led 
RS1 = ponte raddriz. 100 V 1 A 
FI = fusibile 145 mA 
TI = trasform. 3 watt (TN00.01 ) 
sec. 15 volt 0,2 amper 
SI = interruttore 


Fig.3 Schema elettrico dello stadio di alimentazione pubblicato sulla rivista N.172/173. 


ne posto in conduzione dal transistor NPN siglato 
TR4, pilotato dall’inverter IC1/B collegato sul pie¬ 
dino 3 (DI) del CONN.1. 

Dopo aver testato il micro, se tutto risulta regola¬ 
re inizia la fase di programmazione ed il pro¬ 
gramma da noi scritto ed assemblato viene trasfe¬ 
rito dal computer verso il microprocessore inserito 
nello zoccolo textool. 

Durante la fase di programmazione il computer in¬ 
via sul piedino 3 (DI) del CONN.1 un livello logi¬ 
co 0 che, raggiungendo l’ingresso dell’inverter 
IC1/B, viene convertito in un livello logico 1. 
Poiché l’uscita di IC1/B risulta collegata sulla Ba¬ 
se di TR4, questo transistor si porta in conduzione 
polarizzando la Base del transistor PNP siglato 
TR3. In questo modo la tensione positiva di 13,2 
volt applicata sul suo Emettitore può fuoriuscire dal 
suo Collettore raggiungendo il piedino 3 (Vpp) del 
micro. 

La tensione di 13,2 volt non può raggiungere il pie¬ 
dino Vcc per la presenza del diodo DS5, quindi su 
questo piedino ritroveremo sempre 5 volt anche se 
sul piedino Vpp vi sono 13,2 volt. 

Il programma viene inviato dal computer verso il 
micro in forma seriale tramite il piedino 5 (D3) del 

CONN.1. 

Tramite il piedino 4 (D2) del CONN.1 il computer 
invia sul piedino OSC.IN. del micro un impulso di 
clock che, in fase di programmazione, sincroniz¬ 
za i dati inviati sul piedino 5 (PB3) del micro. 

In fase di lettura, che serve per verificare se tutti i 
dati contenuti nel micro sono stati correttamente 
memorizzati, i dati vengono prelevati in forma se¬ 
riale dal piedino 4 (PB2) ed inviati verso il compu¬ 
ter tramite il piedino 11 (BUSY) del CONN.1. 



Fig.4 Foto del circuito di alimentazione. 
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Fig.5 Connessioni dell’integrato 74HC14 vi¬ 
ste da sopra e dei transistor BC.328, BC.547 
ed integrato 78L05 viste da sotto. 





























GND TEST/Vpp 




ST 62/60 


Fig.6 Entrambi i microprocessori tipo ST62T60 (non cancellabili) e gli ST62E60, che ri¬ 
sultano cancellabili, hanno 20 piedini. Questi micro hanno 4K di memoria program¬ 
mabile e 128 bytes di memoria EEprom, più tre porte indicate A-B-C. La porta A ha 4 
entrate/uscite, la porta B ha 6 entrate/uscite e la porta C ha 3 entrate/uscite. 


Vcc 


GND TEST/Vpp 




ST 62/65 


Fig.7 Entrambi i microprocessori tipo ST62T65 (non cancellabili) e gli ST62E65, che ri¬ 
sultano cancellabili, hanno 28 piedini. Questi micro hanno 4K di memoria program¬ 
mabile e 128 bytes di memoria EEprom, più tre porte indicate A-B-C. La porta A ha 8 
entrate/uscite, la porta B ha 8 entrate/uscite e la porta C ha 5 entrate/uscite. 

















































































































































REALIZZAZIONE PRATICA 

Per realizzare questo programmatore oltre al kit si¬ 
glato LX.1325 dovete procuravi anche il kit di ali¬ 
mentazione siglato LX.1170/B, che è lo stesso u- 
tilizzato per il precedente programmatore presen¬ 
tato sulla rivista N.172/173. 

Sul circuito stampato LX.1325 dovete montare tut¬ 
ti i componenti disponendoli come visibile in fig.10. 
Quando si effettuano questi montaggi si inizia nor¬ 
malmente dagli zoccoli e dai connettori perché la 
vista non è ancora affaticata e pertanto ci possia¬ 
mo accorgere senza difficoltà se ci siamo dimenti¬ 
cati una stagnatura o se una grossa goccia di sta¬ 
gno ha cortocircuitato assieme due piedini. 



Fig.8 In questa foto è visibile lo stampato 
del programmatore LX.1325 visto dal lato 
sul quale sono montati tutti i componenti. 


Proseguendo nel montaggio inserite tutte le resi¬ 
stenze e, dopo queste, tutti i diodi rispettando la 
loro polarità. 

La fascia bianca del diodo DS1 con corpo plasti¬ 
co deve essere rivolta verso sinistra. 

Il diodo zener DZ1, riconoscibile perché sul suo 
corpo è stampigliato il numero 8,2, deve avere la 
fascia bianca rivolta verso l’alto. 

La fascia nera dei diodi al silicio siglati DS2 - DS3 
- DS4 deve essere rivolta come risulta bel visibile 
nello schema pratico di fig.10. 

La fascia nera del diodo schottky DS5, che si ri¬ 
conosce dagli altri perché il suo corpo è di colore 
blu, va rivolta verso sinistra. 

Completato il montaggio di questi componenti sta¬ 
gnate tutti i condensatori poliesteri, ricordandovi 


r ìf 8 * a 8 I I a « f f | 



Fig.9 Lo stesso circuito visto dal lato op¬ 
posto. Notate i due condensatori C6-C9 fis¬ 
sati vicino ai due zoccoli textool. 



































Fig.10 Schema pratico di montaggio della 
scheda LX.1325 da utilizzare per la pro¬ 
grammazione dei micro ST62/60-65. Fac¬ 
ciamo presente che questo programmatore 
NON può essere usato per i normali micro 
della famiglia ST62T10-15-20-25 e nemme¬ 
no per i micro ST62E15-20-25. 

Il programmatore andrà collegato alla por¬ 
ta parallela LPT1 del computer e non sulla 
porta siglata LPT2 (leggere articolo). 

Lo stadio di alimentazione siglato 
LX.1170/B, visibile in alto a destra, è stato 
presentato sulla rivista N.172/173 per ali¬ 
mentare il primo programmatore LX.1170. 










































































che i due soli condensatori C6 - C9 devono esse¬ 
re inseriti sul lato opposto del circuito stampato, co¬ 
me risulta ben evidenziato anche in fig.9. 

Quando inserite il condensatore elettrolitico C3 ri¬ 
volgete il suo terminale positivo verso il basso. 

A questo punto potete inserire il transistor TRI , si¬ 
glato BD.140, rivolgendo il lato del corpo con il me¬ 
tallo verso la resistenza RI. 

Ora prendete i minuscoli integrati stabilizzatori IC2 

- IC3 - IC4, sul loro corpo c’è la sigla 78L05, ed in¬ 
seriteli nelle posizioni visibili nello schema pratico 
di fig.10, rivolgendo la parte piatta del loro corpo 
verso destra. 

I transistor TR2 - TR4, siglati BC.547, vanno sta¬ 
gnati sotto la resistenza R3, rivolgendo la parte 
piatta dell’uno verso la parte piatta dell’altro. 

II transistor TR3, siglato BC.328, va inserito ac¬ 
canto al diodo zener DZ1 rivolgendo la parte piat¬ 
ta del suo corpo verso destra. 

Fate attenzione a non confondere i transistor TR2 

- TR4 che sono degli NPN con il transistor TR3 che 
è invece un PNP. 

Completato il montaggio, potete inserire nel suo 
zoccolo l’integrato IC1 rivolgendo la sua tacca di ri¬ 
ferimento a forma di U verso destra. 


Ora potete montare il kit LX.1170/B stagnando sul 
suo circuito stampato tutti i suoi componenti. 

Guardando l’eloquente schema pratico di fig.10 ri¬ 
teniamo che nessuno incontrerà difficoltà ad ese¬ 
guire questo semplice montaggio. 


MONTAGGIO nel MOBILE 

Il mobile di questo programmatore, di tipo a con¬ 
solle e perfettamente identico a quello del prece¬ 
dente programmatore per ST6 (vedi fig.14), confe¬ 
risce al progetto un aspetto decisamente profes¬ 
sionale. 

Come potete vedere in fig.11, lo stadio di alimen¬ 
tazione LX.1170/B va collocato sulla base del se¬ 
micoperchio con tre distanziatori con base autoa¬ 
desiva, mentre lo stampato LX.1325 va fissato sul 
pannello frontale con quattro viti in ferro. 

Prima di avvitare questo stampato vi consigliamo 
di inserire sul piccolo pannello inclinato la gemma 
cromata per il diodo led e l’interruttore a levetta 
SI dello stadio di alimentazione. 

Effettuati i pochi collegamenti richiesti, il program¬ 
matore è già pronto per esplicare la sua funzione. 



Fig.11 Aperto il mobile plastico a consolle visibile in fig.1, fissate sulla base del semico¬ 
perchio lo stadio di alimentazione LX.1170/B con quattro distanziatori autoadesivi, e sull’al¬ 
tro semicoperchio lo stampato LX.1325 avvitandolo con quattro viti. 

NOTA = sul pannello frontale fissate le quattro viti con i loro dadi, in modo da creare un 
piccolo spessore che terrà distanziato lo stampato dal pannello frontale. 




























































Fig.12 Sul pannello di 
alluminio posto sul re¬ 
tro del mobile verrà fis¬ 
sato il connettore di u- 
scita per il computer. 


COME caricare il PROGRAMMA 

Assieme al kit riceverete un dischetto floppy con¬ 
tenente il programma per programmare tutti i mi¬ 
croprocessori della famiglia ST62/60-65, più sei 
supplementari programmi che vi aiuteranno a ca¬ 
pire come usare le funzioni PWM ed EEprom. 

Per caricare il dischetto nell’Hard-Disk seguite le 
nostre istruzioni. 

Inserite il dischetto nell’unità floppy poi digitate: 

C:\>A: premete Enter 

A:\>installa premete Enter 

Il programma una volta caricato occupa circa 1 Me¬ 
gabyte di memoria. 



Fig.13 Una volta scompattati tutti i pro¬ 
grammi inseriti nel disco floppy, apparirà 
sul monitor questa scritta. Per proseguire 
potete pigiare un tasto qualsiasi. 


Nota importante: per caricare il programma usa¬ 
te le due sole istruzioni sopra riportate, perché so¬ 
lo così il programma verrà scompattato ed auto¬ 
maticamente verrà creata una directory chiamata 
ST626 per poterla distinguere da quella del prece¬ 
dente programma che avevamo chiamata ST6. 
Per copiare il contenuto del dischetto non usate né 
il Copy del Dos o altri programmi come il PCshell 
- PCtoois - Norton ecc., perché non riuscireste a 
memorizzarlo nel vostro hard-disk. 

Durante la scompattazione del programma appa¬ 
rirà sul monitor l’elenco di tutti i files e ad opera¬ 
zione conclusa leggerete la scritta visibile in fig.13. 

Completata l’operazione d’installazione potrete to¬ 
gliere il dischetto dal drive e porlo in un cassetto. 


PER RICHIAMARE il PROGRAMMA 

Per richiamare questo programma dovete sempli¬ 
cemente digitare queste due sole istruzioni: 

C:\>CD ST626 premete Enter 

C:\ST626>ST6 premete Enter 


I 6 PROGRAMMI di TEST 

Prima di trasferire aN’interno della memoria vergi¬ 
ne di un micro ST62/60 o ST62/65 uno dei sei pro¬ 
grammi di test che abbiamo inserito nel dischetto, 
dovete collocare il micro nel suo zoccolo textool 
poi bloccarlo con la sua levetta. 

Dopo aver richiamato il programma digitando: 

C:\>CD ST626 premete Enter 

C:\ST626>ST6 premete Enter 
















































Fig.14 Se avete già costruito il precedente programmatore per gli ST6, siglato LX.1170 (ve¬ 
di rivista N.172/173), mettetelo a confronto con il modello LX.1325 da utilizzare solo per 
gli ST62/60-65 e noterete che hanno la stessa estetica. Questi mobili non sfigureranno an¬ 
che se messi vicino ai più moderni ed eleganti computer. 


selezionate quale dei sei programmi-test volete u- 
tilizzare pigiando il tasto funzione F3. 

Sul monitor appariranno i nomi dei files di test: 

PWM60.ASM 

PWM65.ASM 

EEPROM60.ASM 

EEPROM65.ASM 

EEPR60T.ASM 

EEPR65T.ASM 


NOTE IMPORTANTI 

Selezionate il file PWM60 o EEPROM60 o EE- 
PR60T solo se avete inserito nello zoccolo textool 
il micro ST62E60 o ST62T60. 

Selezionate il file PWM65 o EEPROM65 o EE- 
PR60T solo se avete inserito nello zoccolo textool 
il micro ST62E65 o ST62T65. 

Potete memorizzare nel micro uno solo di questi 
sei programmi, perciò se volete testare più pro¬ 
grammi dovrete utilizzare un secondo micro oppu¬ 
re cancellare con una lampada ultravioletta ciò 
che già avete memorizzato. 

Il kit di questa lampada è riportato sulla rivista 
N.174 e la sua sigla è LX.1183. 

Per vedere come funzionano i programmi di test 
dovete necessariamente realizzare il nuovo Bus 
LX.1329, che può ricevere le schede già usate per 
il precedente programmatore per ST6, cioè: 

- scheda LX.1204, pubblicata sulla rivista N.179, 
provvista di quattro display. 


- scheda LX.1206, pubblicata sulla rivista N.180, 
provvista di quattro Triac. 

Il Bus deve essere alimentato con l’alimentatore si¬ 
glato LX.1203 pubblicato sulla rivista N.179, lo 
stesso che usate per alimentare il Bus del prece¬ 
dente programmatore LX.1170. 

Su questa stessa rivista trovate la spiegazione 
dello schema elettrico e dello schema pratico del 
Bus LX.1329 e tutte le istruzioni per eseguire i no¬ 
stri test. 


COSTO di REALIZZAZIONE 

Tutti i componenti necessari alla realizzazione del 
kit LX.1325 (vedi fig.10) completo di circuito stam¬ 
pato, zoccoli textool, transistor, integrati, più il di¬ 
schetto floppy DF.1325 contenente i programmi 
per la programmazione degli ST62/60-65 e quelli 
di test per EEPROM e PWM, ma Esclusi il mobi¬ 
le e l’alimentatore LX.1170 .€ 51,65 

Il solo mobile MO.1325 completo di due mascheri¬ 
ne forate a serigrafate.€ 16,01 

Costo dello stadio di alimentazione LX.1170/B pub¬ 
blicato sulla rivista N.172/173 .€ 11,60 

Costo del solo stampato LX.1325 .€ 7,49 

Costo di un cavo parallelo tipo CA.05 completo di 
connettori maschio e femmina.€ 4,13 

I prezzi riportati sono compresi di IVA, ma non del¬ 
le spese postali che verranno addebitate solo a chi 
richiederà il materiale in contrassegno. 

































BUS per TESTARE le 


Per impratichirvi con la funzione PWM e la memoria EEPROM presenti 
nei micro della famiglia ST62/60-65 realizzate il Bus che vi presentiamo 
ed utilizzatelo insieme alla scheda Display LX.1204 oppure alla scheda 
Triac LX.1206, che vi sono servite per il precedente programmatore. 


Per poter usare al meglio una nuova famiglia di mi¬ 
cro è indispensabile fare un po’ di pratica, e poiché 
sappiamo che non troverete in nessun manuale un 
valido aiuto (quelli da noi personalmente visionati 
sono pieni di errori o informazioni inesatte) abbia¬ 
mo ritenuto opportuno aggiungere ai files per la pro¬ 
grammazione, che trovate nel dischetto DF.1325, i 
programmi di test per provare la memoria EEprom 
e la funzione PWM. 

Poiché in commercio non è facile trovare Bus per 
i micro ST62/60-65 a prezzi contenuti, noi abbia¬ 
mo risolto questo problema con il kit LX.1329, che 
potete alimentare con il kit siglato LX.1203, pub¬ 
blicato sulla rivista N.179. 


SCHEMA ELETTRICO del BUS 

Lo stadio oscillatore ottenuto con il Nand siglato 
IC1/B ci permette di ottenere la frequenza di clock 
di 8 MHz che viene trasferita con il Nand IC1/C sul 


piedino 14 del micro ST62/60 e con il Nand IC1/D 
sul piedino 20 del micro ST62/65. 

Questi due micro sono quelli che, una volta pro¬ 
grammati, dovranno essere inseriti nei due zoccoli 
presenti sullo stampato del Bus (vedi fig.1). 

Le due tensioni dei 12,6 volt e dei 5,6 volt ven¬ 
gono prelevate dall’alimentatore LX.1203, pubbli¬ 
cato sulla rivista N.179, di cui riportiamo nuova¬ 
mente in fig.29 l’elettrico nel caso in cui non ave¬ 
ste questo numero della rivista. 

REALIZZAZIONE PRATICA 

In possesso dello stampato LX.1329 potete inizia¬ 
re il montaggio inserendo i due zoccoli da 28 e 20 
piedini per i micro ST62/65 ed ST62/60, poi quel¬ 
lo da 14 piedini per l’integrato IC1 (vedi fig.4). 
Dopo gli zoccoli fissate il connettore a 24 pin si¬ 
glato CONN.1 ed i due connettori a 4 pin che ser¬ 
viranno per innestare le tre schede sperimentali 
LX.1204 - LX.1206 - LX.1329/B. 









































































Vicino all’integrato IC1 inserite il quarzo da 8 MHz 
fissando il suo corpo in posizione orizzontale. 

Sul lato destro dello stampato inserite il pulsante 
PI , poi la morsettiera a 3 poli e vicino a questa i 
due diodi al silicio DS1 - DS2 rivolgendo la loro fa¬ 
scia di riferimento di colore bianco verso sinistra. 
Completato il montaggio inserite nel suo zoccolo 
l’integrato IC1 rivolgendo la tacca di riferimento a 
forma di U verso l’alto. 

Se in sostituzione dei normali zoccoli per i due mi- 
cro ST62/60 e ST62/65 utilizzate due zoccoli tex- 
tool, risulterà più facile inserirli ed estrarli, ma co¬ 
me saprete, questi zoccoli sono molto costosi. 

PER RICHIAMARE il PROGRAMMA 

Dopo aver memorizzato nell’hard-disk il program¬ 
ma, per richiamarlo dovete semplicemente digita¬ 
re due sole istruzioni: 

C:\>CD ST626 premete Enter 
C:\ST626>ST6 premete Enter 


Prima di trasferire all’interno della memoria vergi¬ 
ne di un micro ST62/60 o ST62/65 uno dei 6 pro¬ 
grammi di test, inserite il micro nel suo zoccolo 
textool poi bloccatelo con la sua levetta. 


Quando sul monitor appare la finestra di fig.5 do¬ 
vete premere il tasto funzione F3. 

Sullo schermo vengono visualizzati i nomi dei no¬ 
stri programmi di test (vedi fig.6). 


EEPR60T.ASM 

EEPR65T.ASM 

EEPROM60.ASM 

EEPROM65.ASM 

PWM60.ASM 

PWM65.ASM 


per i micro ST62/60 
per i micro ST62/65 
per i micro ST62/60 
per i micro ST62/65 
per i micro ST62/60 
per i micro ST62/65 


In ogni micro potete inserire uno solo programma, 
quindi per provare un secondo programma dovete 
cancellare la sua memoria con una lampada ul¬ 
travioletta oppure utilizzare un altro micro. 


funzioni PWM e EEPROM 
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Fig.1 Applicando in 
questo nuovo Bus si¬ 
glato LX.1329 le sche¬ 
de Display e Triac già 
utilizzate per il prece¬ 
dente Bus potrete ve¬ 
dere come funzionano 
la EEPROM ed il PWM. 
Negli zoccoli andrà in¬ 
serito un micro pro¬ 
grammato con i nostri 
programmi di test. 
































DS1 



12.6 V. 

5.6 V. 

Massa 


Fig.2 Schema elettrico del Bus LX.1329 da usare per i soli micro della serie ST62/60 e 
ST62/65. Questo Bus deve essere alimentato con il circuito LX.1203, che abbiamo già pre¬ 
sentato sulla rivista N.179, riportato nelle figg.29-31. Se possedete già questo alimenta¬ 
tore non sarà necessario montarne un secondo. I due rettangoli NERI con sopra stampi¬ 
gliato ST62/60-ST62/65 sono i due zoccoli (vedi fig.4) nei quali dovrete inserire i due mi¬ 
cro che avrete programmato con i programmi test per EEPROM e PWM. 


ELENCO COMPONENTI LX.1329 

RI = 2,2 megaohm 
R2 = 1.000 ohm 
R3 = 100.000 ohm 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 10 pF ceramico 
C4 = 10 pF ceramico 
C5 = 1 mF elettrolitico 


C6 = 100.000 pF poliestere 
C7 = 100 mF elettrolitico 
XTAL = quarzo 8 MHz 
DS1 = diodo tipo 1N.4007 
DS2 = diodo tipo 1N.4007 
IC1 = C/Mos tipo 74HC00 
CONN.1 = connettore 24 poli 
PI = pulsante 



74 HC 00 















































































































Fig.3 Foto del Bus che ci 
servirà per ricevere le 
schede LX.1204 - LX.1206 
- LX.1329/B per i test. 


Fig.4 In basso lo schema 
pratico di montaggio del 
Bus siglato LX.1329. 




= 12,6 V. 
= 5,6 V. 
=3= Massa 

VERSO 
LX1203 























































































TEST con EEPROM tipo ST62E60 


Inserite un micro ST62E60, cioè del tipo cancella¬ 
bile, nello zoccolo del programmatore LX.1325. 

Dopo aver richiamato il programma, premete il ta¬ 
sto F3 in modo da far apparire i nomi dei files e 
portate il cursore sulla riga: 

EEPROM60.ASM premete Enter 

Appariranno così le istruzioni del programma con i 
relativi commenti (vedi fig.7). 

A questo punto tenendo pigiato il tasto ALT pigia¬ 
te il tasto T per visualizzare la finestra di fig.8. 
Premete il tasto R e subito apparirà la finestra di 
programmazione con una infinità di sigle di micro- 
processori (vedi fig.9). 

ST62E60 

ST62E60B 

ST62T60 

ST62T60B 

ST62E65 

ST62E65B 

ST62T65 

ST65T65B 

Importante: nessuno si è mai preso la briga di pre¬ 
cisare se conviene scegliere il micro senza la B fi¬ 
nale oppure quello con la B finale, per cui ora vi 
spiegheremo come sceglierli. 

Se sul corpo del vostro micro è stampigliata la si¬ 
gla ST62E60/B dovete selezionare ST62E60. 

Se sul corpo del vostro micro è stampigliata la si¬ 
gla ST62E60/BB dovete selezionare ST62E60B. 

Se sul corpo del vostro micro è stampigliato la si¬ 
gla ST62T60/B dovete selezionare ST62T60. 

Se sul corpo del vostro micro è stampigliata la si¬ 
gla ST62T60/BB dovete selezionare ST62T65B. 

Quanto detto sopra vale anche per gli ST62/65. 

Poiché il primo programma-test funziona su un mi¬ 
cro cancellabile ST62E60, prima di scegliere la ri¬ 
ga di programmazione controllate attentamente 
quale sigla è presente sul vostro micro. 

Se trovate ST62E60/B selezionate ST62E60. 

Se trovate ST62E60/BB selezionate ST62E60B. 

A questo punto pigiate L = Load e nella finestra 
che appare (vedi fig.10) scrivete il nome del pro- 



Fig.5 Per trasferire un programma dal com¬ 
puter ad un micro dovete usare il program¬ 
matore LX.1325. Dopo aver richiamato il 
programma, quando appare questa finestra 
premete il tasto F3. 


ame 


EEPROH6Q.ASM 



EEPROH65.ASH 
PWM60.ÀSH 
PTJM65. ASH 



C:\ST62 6X\* . ASH 

EEPROH6Q . ASH 0 _ Oct 28, 1997 06:48p 


Fig.6 Pigiando F3 apparirà la finestra con i 
nomi dei 6 files dei programmi di test. In un 
micro potete inserire 1 solo programma, 
quindi per provarne un secondo dovrete 
prima cancellare la sua memoria. 



Fig.7 Scelto il programma che volete me¬ 
morizzare, sul video appariranno tutte le i- 
struzioni con il relativo commento. 
Leggendo queste istruzioni potete impara¬ 
re come va impostato un programma. 

























gramma, cioè EEPROM60 tralasciando .ASM, 
quindi premete Enter e quando appare la finestra 
con la scritta File checksum premete Enter. 

Apparirà così una finestra bianca. Se ora premete 
il tasto P = Prg e di seguito il tasto N, dopo pochi 
secondi apparirà la scritta: 

Verifying thè target chip ... Please Wait 

Verifica chip da programmare ... attendi 

Se tutto risulta regolare apparirà la scritta: 

Programming thè targhet chip ... Please Wait 

Programmazione in corso ... attendi 

L’operazione di scrittura dal computer verso il mi- 
cro richiede circa 10 - 14 secondi. 

A programmazione completata sul monitor appare 
questa scritta: 

The device is succesfully programmed 

Il micro è stato correttamente programmato 

Ora potete estrarre dal programmatore il micro già 
programmato per posizionarlo nello zoccolo della 
scheda Bus LX.1329, a cui avrete collegato la 
scheda con i quattro display siglata LX.1204, pub¬ 
blicata sulla rivista N.179. 

Sulla morsettiera del Bus dovete applicare due ten¬ 
sioni di 12,6 e 5,6 volt più il filo di massa, che pre¬ 
levate dal kit LX.1203. 

Il programma EEprom che avete memorizzato nel 
micro è un timer con 4 diversi cicli che contano 
all’indietro. 

Se sul Bus risultasse collegata in parallelo alla 
scheda LX.1204 anche la scheda del relè siglata 
LX.1205, pure questa pubblicata sulla rivista 
N.179, con il primo ciclo vedreste apparire 00:20 e 
contemporaneamente eccitarsi il relè RL1, che si 
disecciterà quando il conteggio arriverà a 00:00. 

Con il secondo ciclo apparirà sui display 01:30, e 
se fosse presente la scheda LX.1205 vedremmo 
eccitarsi il RL2, che si disecciterà quando il con¬ 
teggio arriverà a 00:00. 

Il terzo ciclo partirà dal numero 00:47 ed il quarto 
ciclo dal numero 03:00. 

Quello che abbiamo voluto mettere in evidenza con 
questo programma è la funzione della memoria 
EEprom. 



Fig.8 Pigiando ALT e T vedrete apparire sul¬ 
lo schermo questa piccola finestra. 



Fig.9 Premendo R vedrete apparire tutte le 
sigle dei micro che potete programmare. 



Fig.10 Scelto il micro pigiate L e digitate il 
nome del programma da trasferire. 



Fig.11 II programma EEPR65T.ASM deve 
essere memorizzato nei micro ST62/65. 













































Se togliamo di proposito la tensione di alimenta¬ 
zione al Bus quando sui display appare il numero 
01:34 o qualsiasi altro numero, il numero rimarrà 
comunque memorizzato nella EEprom. 

Infatti alimentandolo nuovamente dopo 10 minuti, 
oppure dopo 3 ore o anche dopo 1 mese, vedre¬ 
te riapparire sui display lo stesso numero che ri¬ 
sultava presente al momento dello spegnimento e, 
da questo numero, ripartirà il conteggio all’indietro. 

Per variare i tempi da noi prefissati, nel program¬ 
ma dovrete modificare queste righe: 

1 ° ciclo = righe 626-627 
2° ciclo = righe 635-636 
3° ciclo = righe 643-644 
4° ciclo = righe 651-652 

Portiamo qualche esempio. 

Se volete che il 1 0 ciclo abbia una durata di 2 mi¬ 
nuti e 30 secondi dovete inserire nel riga 626 i se¬ 
condi e nella 627 i minuti: 

Idi stsex,30 ; 626 tempo in secondi 

Idi stmix,2 ; 627 tempo in minuti 

set 6,port_b ; setta l’uscita 6 di port Bai 

La riga 628 serve per portare a livello logico 1 il 
piedino 6 della porta B, così da poterlo utilizzare 
per eccitare un relè oppure dei Triac tramite un cir¬ 
cuito pilota. 

Dopo 2 minuti e 30 secondi, il nuovo tempo da 
voi impostato, il programma passa al 2° ciclo che 
porta a livello logico 0 il piedino 6 (riga 637) e a 
livello logico 1 il piedino 7 (riga 638). 

Se volete modificare i tempi del 2° ciclo per por¬ 
tarlo ad esempio a 45 secondi, dovete modificare 
la riga 635 inserendo questo numero e scrivere nel¬ 
la riga 636 0 minuti: 



Fig.12 Per vedere il contenuto di una EE¬ 
PROM pigiate sulla casella LOAD. 



Fig.13 Quando appare questa finestra pi¬ 
giate Barra e Enter per andare su EEprom. 



Fig.14 Portate il cursore sulla finestra in al¬ 
to con scritto READ poi pigiate Y. 


Idi stsex,45 
Idi stmiXjO 
res 6,port_b 
set 7,port_b 


; 635 tempo in secondi 
; 636 tempo in minuti 
; resetta l’uscita 6 di port B a 0 
; setta l’uscita 7 di port Bai 


Se nel 1 ° ciclo voleste portare il piedino 6 a livel¬ 
lo logico 0 per la durata di 2 minuti e 30 secondi 
modificate il programma come qui sotto riportato: 


Idi 

Idi 

res 


stsex,30 ; 290 tempo in secondi 
stmix,2 ; 291 tempo in minuti 
6,port_b ; resetta l’uscita 6 di port B a 0 


OELECTRONICS 



Fig.15 Quando apparirà questa finestra pi¬ 
giate 2 volte di seguito il tasto Enter. 


Per portare a livello logico 1 il piedino 6 della por- 












































ta B nel 2° ciclo, modificate il programma così: 


Idi stsex,45 ; 296 tempo in secondi 

Idi stmix,0 ; 297 tempo in minuti 

set 6,port_b ; setta l’uscita 6 di port Bai 

I PULSANTI PI - P2 

I pulsanti PI - P2 sulla scheda display permettono 
di bloccare, far ripartire e resettare il conteggio. 

Premendo in successione PI bloccate e fate ri¬ 
partire il conteggio dal numero sul quale era stato 
fermato. Dopo aver bloccato il conteggio con PI, 
premendo il tasto P2 il programma verrà resetta¬ 
to. In questo caso quando premerete PI il con¬ 
teggio ripartirà sempre dal 1 ° ciclo. 

TEST con EEPROM tipo ST62E65 

Inserite un micro ST62E65 nello zoccolo del pro¬ 
grammatore LX.1325 e, dopo aver richiamato il pro¬ 
gramma, premete il tasto F3 in modo da far appa¬ 
rire i nomi dei files. 

Portate il cursore sulla riga: 

EEPR65T.ASM premete Enter 

In questo modo appaiono le istruzioni del pro¬ 
gramma con i relativi commenti (vedi fig.11). 

A questo punto tenendo pigiato il tasto ALT pigia¬ 
te il tasto T ed apparirà la finestra di fig.8. 
Premete il tasto R e quasi subito apparirà la fine¬ 
stra di programmazione con tutte queste sigle. 

ST62E60 

ST62E60B 

ST62T60 

ST62T60B 

ST62E65 

ST62E65B 

ST62T65 

ST65T65B 

Se sul corpo del vostro micro è stampigliata la si¬ 
gla ST62E65/B6 dovete selezionare ST62E65. 

Se sul corpo del vostro micro è stampigliata la si¬ 
gla ST62E65/BB6 dovete selezionare ST62E65B. 

Pigiate L = Load e nella finestra che appare (vedi 
fig.12) digitate il nome del programma, cioè EE- 
PR65T tralasciando .ASM, quindi premete Enter e 
quando appare la finestra con la scritta File check- 
sum premete Enter. 

Apparirà una finestra bianca e a questo punto po¬ 
tete pigiare il tasto P = Prg poi pigiate il tasto N. 



Fig.16 Andate sulla scritta rAm poi pigiate 
Enter e sullo schermo apparirà il contenu¬ 
to della EEprom. Notate nella prima riga i 
dati memorizzati nella EEprom. 



Fig.17 Se nella EEprom non è memorizzato 
nessun dato, vedrete tutti 00 oppure tutti 
FF. Normalmente FF è presente nei soli mi¬ 
cro OTP non cancellabili. 



Fig.18 Per ripulire una EEprom andate sul¬ 
la riga FILL e quando appare questa fine¬ 
stra scrivete nella terza riga FF, poi andate 
sull’ultima riga e pigiate il tasto Y. 





















































Fig.19 Inserendo nel bus la scheda 
con display LX.1204 ed anche un mi- 
cro ST62/60 programmato con il pro¬ 
gramma Test EEPROM60, potete ve¬ 
dere come un dato memorizzato nel¬ 
la EEprom non si cancelli anche 
quando si toglie la tensione di ali¬ 
mentazione al Bus. 


Fig.20 Inserendo nel bus la scheda 
con Triac LX.1206 ed anche un mi- 
cro ST62/65 programmato con il pro¬ 
gramma Test EEPR65T, togliendo la 
tensione di alimentazione e poi rein¬ 
serendola il programma ripartirà 
sempre dalla lampada che risultava 
accesa in precedenza. 










Fig.21 Inserendo nel bus la scheda 
LX.1329/B (vedi fig.28) potrete vede¬ 
re come funziona il PWM. 
Modificando le righe del programma 
come spiegato nell’articolo riuscire¬ 
te a fare un po’ di pratica che vi sarà 
molto utile per poter usare corretta- 
mente la EEprom e il PWM. 





































Quando il micro risulterà programmato sul monitor 
apparirà la scritta: 

The device is succesfully programmed 

Il micro è stato correttamente programmato 

A questo punto potete estrarre dal programmato- 
re il micro già programmato per inserirlo nella 
scheda Bus LX.1329 alla quale dovete collegare la 
scheda del kit LX.1206, pubblicata sulla rivista 
N.180, provvista di quattro Triac. 


Nel programma EEPR65T è inserito un timer che 
provvede ad accendere e spegnere a ciclo conti¬ 
nuo le quattro lampade collegate ai Triac. 

Anche questo programma utilizza la memoria EE- 
prom. Infatti se togliete la tensione di alimentazio¬ 
ne al Bus quando una delle lampade è accesa, a- 
limentandolo nuovamente dopo 10 minuti oppure 
dopo 3 ore o anche dopo 1 mese, si riaccenderà 
la lampada che risultava accesa al momento dello 
spegnimento, perché questo dato è stato memo¬ 
rizzato nella EEprom. 


Se volete che il 1 ° ciclo abbia una durata di 5 se¬ 
condi, modificate nel modo seguente le righe 626 

- 627 del programma: 

Idi stsex,5 ; 626 tempo in secondi 

Idi stmix,0 ; 627 tempo in minuti 

set 6,port_b ; setta l’uscita 6 di port Bai 

La riga 628 del programma serve per mantenere 
accesa la lampada per il tempo prefissato, dopo¬ 
diché il programma passa al 2° ciclo . 

Per modificare i tempi di accensione dovete ap¬ 
portare modifiche su ognuno dei 4 cicli. Per que¬ 
ste modifiche vi aiuteranno i commenti da noi ri¬ 
portati per ogni riga di programma. 

NOTE IMPORTANTI 

La lampada ad ultravioletti riesce a cancellare il 
programma memorizzato nel micro, ma non can¬ 
cella il contenuto della memoria EEprom. 

Per controllare il contenuto di questa memoria e 
cancellarla procedete come segue: 

- Inserite il micro nel programmatore. 


Se volete variare i tempi di accensione e spegni¬ 
mento delle lampade dovete modificare queste ri¬ 
ghe del programma: 

1 ° ciclo = righe 626-627 
2° ciclo = righe 635-636 
3° ciclo = righe 643-644 
4° ciclo = righe 651-652 


- Posizionatevi nella directory C:\ST626> e digi¬ 
tate quanto sotto riportato: 

C\ST626>ST626xPG premete Enter 

- Nella finestra che appare (vedi fig.9) scegliete il 
tipo di micro inserito nel programmatore poi pigia¬ 
te il tasto Enter. 



Fig.22 Dal piedino d’uscita del PWM non 
esce una tensione continua variabile da 
0 a 5 volt, ma solo delle onde quadre con 
un livello logico 0-1. 

Modificando tramite programma il duty- 
cycle di queste onde quadre, vale a di¬ 
re il tempo che queste rimangono a li¬ 
vello logico 0 e a livello logico 1, riusci¬ 
rete ad ottenere una tensione efficace 
che da un minimo di 0 volt potete ele¬ 
vare fino a un massimo di 5 volt. 












































- Nella pagina che appare (vedi fig.10) andate sul¬ 
la scritta Load e pigiate Enter. 

- Digitate il nome dal file utilizzato, ad esempio EE- 
prom60, poi pigiate Enter. 

- Andate sulla scritta Space, posizionata nella ri¬ 
ga in alto, poi pigiate Enter. 

- Nella finestra di fig.13 andate sulla riga EEPROM 
pigiando il tasto della Barra ed Enter. 

- Per vedere il contenuto della EEPROM andate 
sulla scritta Read poi digitate Y (vedi fig.14) e nel¬ 
la finestra che appare (vedi fig.15) pigiate Enter 

due volte. 

- Andate sulla scritta rAm poi pigiate Enter. Ve¬ 
drete così sullo schermo il contenuto della EEprom 
(vedi fig.16). 

- Se la EEprom non è programmata vedrete tutte 
le celle su FF (vedi fig.17). 

Per Cancellare o Modificare la EEPROM 

- Andate sulla scritta Fili poi pigiate Enter. 

- Nella terza riga della finestra che appare (vedi 
fig.18) scrivete FF, poi andate con il cursore sull’ul¬ 
tima riga in basso, quindi pigiate Y per conferma¬ 
re la modifica. Automaticamente tutte le celle si ca¬ 
richeranno con FF. 

- In sostituzione di FF potreste anche scrivere 00, 
ma è consigliabile usare FF perché le celle dei mi- 
cro OTP sono tutte FF. 

Nota: se volete cancellare o modificare una sola 
cella dovete selezionare Edit. 

Spostando il cursore potrete così portarvi sulla cel¬ 
la che vi interessa modificare. 

- Per uscire pigiate Escape poi X. 

Tenete presente che le modifiche appena appor¬ 
tate non vanno automaticamente a ripulire le EE¬ 
prom, in cui rimarranno memorizzati i vecchi dati. 

Per memorizzare i dati cambiati nelle memorie EE¬ 
prom dovete andare sulla scritta PROG, poi pigia¬ 
re due volte Enter. 

Queste note, che non troverete in nessun manua¬ 
le, vi saranno molto utili perché vi permetteranno 
di vedere concretamente e, volendo di modifica¬ 
re manualmente, il contenuto delle EEprom. 
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Fig.23 Se l’onda quadra generata dal PWM 
rimane a livello logico 1 per i suoi totali 256 
step, in uscita otterrete 5 volt. 
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Fig.24 Se l’onda quadra rimane a livello lo¬ 
gico 1 per 200 step su 256 step totali, ot¬ 
terrete una tensione di soli 3,9 volt. 
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Fig.25 Se l’onda quadra rimane a livello lo¬ 
gico 1 per 128 step, otterrete in uscita una 
tensione di soli 2,5 volt. 
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Fig.26 Riducendo a soli 20 step il livello lo¬ 
gico 1 dell’onda quadra, otterrete in uscita 
una tensione di soli 0,39 volt. 

























































TEST PWM con ST62/60-65 

Per questo programma-test si può usare sia un 
micro ST62E60 sia un micro ST62E65. 

Prima di presentarvi il nostro programma, è ne¬ 
cessario spiegare come si fa con la tecnica PWM 
a trasformare i livello logici 1 - 0 in un valore di 
tensione continua variabile. 

Come già sapete il livello logico 1 corrisponde ad 
una tensione di 5 volt positivi ed il livello logico 
0 ad una tensione di zero volt. 

Poiché il minimo numero decimale che possiamo 
usare è 0 ed il massimo numero 255, agendo sul 
registro PWM tramite software si potrà decidere di 
quanti step da 0 a 255 il segnale dovrà rimanere a 
livello logico 1 e di quanti step dovrà rimanere a 
livello logico 0. 

Se programmate il registro PWM in modo che ri¬ 
manga a livello logico 1 da 0 fino a 255, in usci¬ 
ta otterrete la tensione massima di 5 volt (vedi 
fig.23). 

Se programmate il registro PWM in modo che ri¬ 
manga a livello logico 1 dallo step 0 fino a 200 e 
rimanga da questo numero fino a 255 a livello lo¬ 
gico 0, in uscita otterrete una tensione di soli di 3,9 
volt (vedi fig.24). 

Se programmate il registro PWM in modo che ri¬ 
manga a livello logico 1 dallo step 0 fino a 128 e 
rimanga da questo numero fino a 255 a livello lo¬ 
gico 0, in uscita otterrete metà tensione, cioè 2,5 
volt (vedi fig.25). 

A questo punto è abbastanza intuitivo che se pro¬ 
grammate il registro PWM in modo che rimanga a 
livello logico 1 dallo step 0 fino a 20 e rimanga da 
questo numero fino a 255 a livello logico 0, in u- 
scita otterrete una tensione di soli 0,39 volt (vedi 
fig.26). 

Anche se il segnale ad onda quadra che fuoriesce 
dalla porta PB7 raggiunge sempre un picco mas¬ 
simo di 5 volt, dovete considerare il valore dei volt 
efficaci, che risultano proporzionali al tempo che 
l’onda quadra rimane a livello logico 1 e a livel¬ 
lo logico 0. 

In linea di massima si potrebbe calcolare il valore 
di questa tensione dividendo i 5 volt per i 256 li¬ 
velli (da 0 a 255 i livelli sono 256), poi moltiplica- 
re il risultato per il numero degli step in cui l’onda 
quadra rimane a livello logico 1. 


Considerando i valori riportati nelle figg.23-26 ot¬ 
terrete queste esatte tensione: 

(5 : 256) x 256 = 5,0 volt 
(5 : 256) x 200 = 3,9 volt 
(5 : 256) x 128 = 2,5 volt 
(5 : 256) x 20 = 0,39 volt 

Il condensatore CI posto dopo la resistenza RI 
permette di ottenere una tensione continua effi¬ 
cace del treno di onde quadre con il duty-cycle 
variabile che fuoriesce dal PWM. 

Vi starete chiedendo ora a cosa serve una tensio¬ 
ne variabile da 0 a 5 volt se a lato pratico serve u- 
na tensione variabile da 0 a 24 volt oppure da 0 a 

220 volt. 

Anche se vi servisse una tensione variabile da 0 a 
5 volt per accendere una piccola lampadina non 
potremmo mai utilizzarla perché la tensione forni¬ 
ta dal PWM non ha potenza. 

Come potete vedere anche dalla nostra scheda 
sperimentale siglata LX.1329/B, che andrà inne¬ 
stata nel Bus, i 5 volt vengono utilizzati per pilota¬ 
re la Base di un transistor di potenza sul cui Col¬ 
lettore abbiamo inserito una lampadina da 12 volt 
3 watt. 

Inserendo questa scheda nel Bus, nel quale andrà 
inserito anche un micro ST62E60 programmato 
con il programma: 

PWM60.ASM 

noterete quanto segue: 

- Alimentando il Bus la lampadina si accenderà per 
un 50% della sua luminosità. 

- Ogni volta che premete il tasto P2 la luminosità 
della lampadina si attenua, perché la tensione 
scende di volta in volta di 0,5 volt. 

- Ogni volta che premete il tasto PI la luminosità 
della lampadina aumenta, perché la tensione sale 
di volta in volta di 0,5 volt. 

Per modificare il valore del salto di luminosità ogni 
volta che si premono i due pulsanti, dovete varia¬ 
re questi righe di programma: 


STARTPW 

.EQU 

5 

riga 41 

CAPTPW 

.EQU 

130 

riga 42 

MINPW 

.EQU 

30 

riga 43 

STEPW 

.EQU 

25 

riga 44 



Fig.27 Schema elettrico della scheda sigla¬ 
ta LX.1329/B. Come potete vedere in figura 
la tensione variabile da 0 a 5 volt presa su 
B7 del CONN.1 si applica sulla Base del 
transistor TRI che provvede ad accendere 
dal suo minimo al suo massimo una lam¬ 
padina da 12 volt. Collegando un Tester sui 
terminali +/- potrete leggere la tensione for¬ 
nita dal PWM. 


ELENCO COMPONENTI LX.1329/B 

RI = 10.000 ohm 

R2 = 10.000 ohm 

R3 = 22.000 ohm 

R4 = 4.700 ohm 

CI = 100.000 pF poliestere 

C2 = 100.000 pF poliestere 

C3 = 100.000 pF poliestere 

TRI = NPN darlington BDX.53C 

PI = pulsante 

P2 = pulsante 

LP1 = lampada 12 volt 3 watt 
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Fig.28 Schema pratico 
di montaggio della 
scheda LX.1329/B da 
usare per i test PWM. 















































In questo programma abbiamo diviso la frequenza 
del quarzo da 8 MHz per 3 utilizzando il registro 
ARS2, definito nella locazione 0D7H ottenendo co¬ 
sì una frequenza base di 2,667 MHz. 

Quando l’Auto-Reload Timer arriva al numero 
255, ricarica il timer con il numero che abbiamo 
messo nel registro ARRC, che si trova nella loca¬ 
zione di memoria 0D9H. 

Se carichiamo il registro ARRC con il numero 0, il 
timer partirà da 0 per arrivare a 255 e raggiunto 
questo valore massimo ripartirà da 0. 

Se carichiamo il registro ARRC con il numero 127, 
il timer partirà da 127 per arrivare a 255 e raggiunto 
questo valore massimo ripartirà da 127. 

Poiché nel nostro programma abbiamo caricato il 
registro ARRC con il numero 5, il timer ripartirà 
sempre da questo valore e per arrivare a 255 noi 
avremo disponibili 255 - 5 = 250 step. 

Questo significa che per ogni step potremo incre¬ 
mentare il valore efficace dei nostri 5 volt di: 

5 : 250 = 0,02 volt 

Conoscendo il valore degli step (250) e la fre¬ 
quenza base (2,667 MHz) possiamo ricavare la 
frequenza di lavoro del PWM, che nel nostro caso 
sarà pari a: 

2,667 : 250 = 0,0106 MHz (10,6 KHz circa) 

Se nel registro ARRC avessimo messo il numero 
127, il timer sarebbe ripartito sempre da questo va¬ 
lore, quindi per arrivare a 255 avremmo avuto di¬ 
sponibili 255 - 127 = 128 step. 

Vale dire che per ogni step avremmo incrementa¬ 
to il valore efficace dei nostri 5 volt di: 

5 : 128 = 0,039 volt 

Conoscendo il valore degli step (128) e la fre¬ 
quenza base (2,667 MHz), possiamo ricavare la 
frequenza di lavoro del PWM che nel nostro caso 
sarà pari a: 

2,667 : 128 = 0,020 MHz (20 KHz circa) 

Quindi riducendo il numero degli step otterremmo 

un aumento della frequenza di lavoro. 

Di seguito spieghiamo il significato di alcune righe 
di programma. 


STARTPW .EQU 5 (riga 41) = è il valore degli 
step definito in Auto - Reload - Timer, che come 
già abbiamo visto corrispondono ad un valore di 
tensione minima di 0,02 volt. 

CAPTPW .EQU 130 (riga 42) = è il valore del 
comparatore interno che utilizziamo per stabilire 
da quale valore di tensione desideriamo partire. 
Poiché lo StartPW ha un valore di 5, noi partiamo 
da un valore di tensione pari a: 

(130 - 5) x 0,02 = 2,5 volt 

MINPW .EQU 5 (riga 43) = definisce il valore mi¬ 
nimo a cui vogliamo arrivare con la tensione. 
Sottraendo a 5 il valore dello StartPW noi riuscia¬ 
mo a scendere fino ad un valore di: 

(5 - 5) = 0 volt 

STEPW .EQU 25 (riga 44) = in questa riga ab¬ 
biamo inserito il numero di salti di tensione che vo¬ 
gliamo ottenere ogni volta che andiamo a pigiare i 
pulsanti PI o P2. 

Questo numero va moltiplicato per il valore di ten¬ 
sione corrispondenti ad uno step, cioè a 0,02 volt. 
Con il nostro programma facciamo dei salti di: 

25 x 0,02 = 0,5 volt 

Se ad esempio volessimo fare dei salti di 1 volt an¬ 
ziché di 0,5 volt, partendo dal valore minimo di 1 
volt dovremmo modificare le righe 42-43-44 come 
qui sotto riportato: 


CAPTPW 

.EQU 

55 

riga 42 

MINPW 

.EQU 

5 

riga 43 

STEPW 

.EQU 

50 

riga 44 


Se volessimo fare dei salti di soli 0,04 volt parten¬ 
do sempre da un valore minimo di 0 volt, dovrem¬ 
mo modificare così le righe: 

CAPTPW .EQU 5 riga 42 

MINPW .EQU 5 riga 43 

STEPW .EQU 2 riga 44 


MEMORIZZARE un vostro PROGRAMMA 

Fino a qui vi abbiamo spiegato come trasferire i no¬ 
stri programmi di test nella memoria del micro. 
Ovviamente i softwaristi vorranno memorizzare nel 
micro i loro personali programmi e quindi non ci ri¬ 
mane che darvi qualche piccola nota di aiuto. 
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Fig.29 Schema elettrico dello stadio di ali¬ 
mentazione da usare per alimentare il Bus 
LX.1329. Chi ha già realizzato il Bus per il 
precedente programmatore per ST6 potrà 
usare l’alimentatore che già possiede an¬ 
che per questo Bus. 


ELENCO COMPONENTI LX.1203 

CI = 2.200 mF elettr. 35 volt 
C2 = 100.000 pF poliestere 
C3 = 100.000 pF poliestere 
C4 = 100 mF elettr. 35 volt 
C5 = 2.200 mF elettr. 35 volt 
C6 = 100.000 pF poliestere 
C7 = 100.000 pF poliestere 
C8 = 100 mF elettr. 35 volt 
DS1 = diodo 1N.4007 
DS2 = diodo 1N.4007 
RS1 = ponte raddriz 100 V 1 A 
RS2 = ponte raddriz 100 V 1 A 
IC1 = uA.7812 
IC2 = uA.7805 

TI = trasform. 25 watt (T025.01) 
sec. 14 V 1A - 8 V 1 A 
SI = interruttore 


Fig. 30 Foto dello stadio di alimentazione 
già presentato sulla rivista N.179 perché u- 
sato per alimentare il Bus LX.1202 per i nor¬ 
mali micro ST6 senza EEprom e PWM. 














































Innanzitutto precisiamo che l’EDIT da noi inserito 
all’interno del floppy DF.1325 assieme ai program¬ 
mi di test è molto limitato. Non accetta infatti pro¬ 
grammi maggiori di 30 Kilobyte. Se andrete a sal¬ 
vare dei programmi che occupano uno spazio mag¬ 
giore, tutto quello che eccede i 30 Kilobyte verrà 
inesorabilmente cancellato. 

Per modificare o salvare programmi che occupano 
più di 30 Kilobyte dovete obbligatoriamente utiliz¬ 
zare l’EDITOR del DOS presente nel vostro com¬ 
puter. 

Per entrare nel menu principale dell’editor digitate 
queste istruzioni: 

C:\>CD ST626 premete Enter 
C:\ST626>Edit premete Enter 

Dopo aver corretto o modificato il vostro program¬ 
ma, prima di trasferirlo nella memoria del micro do¬ 


vete sempre assemblarlo, quindi uscite dal pro¬ 
gramma pigiando ALT + F, poi ALT + X e così ap¬ 
parirà sul monitor: 

C:\ST626> 

Ora dovete digitare: 

C:\ST626>AST6 -S -L Pluto premete Enter 

Nota: dove noi abbiamo scritto Pluto voi dovete 
scrivere il nome del vostro programma. 

Dopo diversi secondi sul monitor apparirà: 

***SUCCESS*** 

a conferma che l’assemblaggio è stato completa¬ 
to senza riscontrare nessun errore. 





Fig.31 In questo disegno riportiamo lo 
schema pratico di montaggio nel caso qual¬ 
che lettore non avesse a disposizione la ri¬ 
vista N.179.1 due integrati stabilizzatori an¬ 
dranno fissati sopra un’aletta di raffredda¬ 
mento come visibile in fig.30. 



















































Se al posto di questa scritta dovesse apparirne u- 
na di errore, ad esempio: 

ERROR C:\ST626\pluto.ASM 151: 

significa che nella riga 151 esiste un errore, quin¬ 
di rientrate aH’interno del vostro programma e cor¬ 
reggete l’istruzione in tale riga. 

Per fare questa correzione dovete nuovamente ri¬ 
chiamare l’Editor, andare sulla riga 151 e dopo a- 
ver corretto l’istruzione dovete riassemblare il pro¬ 
gramma procedendo come vi abbiamo appena 
spiegato. 

Poiché in fase di compilazione abbiamo usato le 
opzioni -L -S, verranno generati questi 4 files: 

Pluto.DSD 

Pluto.HEX 

Pluto.SYM 

Pluto.LIS 

Il file Pluto.SYM e il file Pluto.DSD serviranno per 
i programmi di simulazione, già conosciuti con i 
nomi di DSE622 e di ST622. 

Il file Pluto.LIS contiene il listato completo del pro¬ 
gramma che potrà risultarvi utile per una consulta¬ 
zione o come copia di salvataggio. 

Quando sul monitor vi appare: 

***SUCCESS*** 

proseguite digitando: 

C:\ST626>ST626xPG premete Enter 

In questo modo apparirà la finestra di fig.9 e a que¬ 
sto punto procedete con le istruzioni riportate a 
pag.110, che vi spiegano come trasferire il pro¬ 
gramma dal computer verso il micro. 

NOTA IMPORTANTE 

Usando il sistema operativo Windows 3.1 non in¬ 
contrerete nessun problema, ma lo stesso non si 
può dire con Windows 95. 

Se usando Windows 95 riscontrate dei problemi 
nel lanciate il programma ST626xPG, VI consi¬ 
gliamo di inserire nell’ultima riga del file CON¬ 
FIG.SYS questa opzione utilizzando il programma 
Edit oppure Notepad o Write o se siete esperti, il 
comando Sysedit: 

SWITCHES /C 


Ora salvate il file, quindi spegnete il computer e 
riaccendetelo. A questo punto non dovreste più 
incontrare nessun problema ad utilizzare il pro¬ 
gramma: 

ST626xPG 

Con tutte queste spiegazioni ed esempi vogliamo 
sperare di aver dissipato buona parte dei dubbi che 
avevate sulle EEprom e sul PWM. 


COSTO di REALIZZAZIONE 

Tutti i componenti necessari per la realizzazione 
del Bus LX.1329 (vedi figg.2-3-4) completo di cir¬ 
cuito stampato e del 74HC00. € 19,60 

Tutti i componenti necessari per la realizzazione 
dell’interfaccia LX.1329/B (vedi figg.27-28) com¬ 
pleta di circuito stampato e di una lampadina da 12 
volt per testare il PWM .€ 8,80 

Costo del solo stampato LX.1329 . €11,10 

Costo del solo stampato LX.1329/B. € 4,29 

Costo di un ST62E60 cancellabile.€ 20,66 

Costo di un ST62T60 non cancellabile.€ 12,39 

Costo di un ST62E65 cancellabile.€ 18,08 

Costo di un ST62T65 non cancellabile.€ 14,98 

COSTO dei precedenti KIT per ST6 

Costo dello stadio di alimentazione LX.1203 (vedi 
fig.30) pubblicato sulla rivista N.179, Escluso il mo¬ 
bile plastico MTK06.22 .€ 25,80 

Costo del mobile plastico MTK06.22 per lo stadio 
di alimentazione.€ 6,97 

Costo del Kit della scheda Display LX.1204 pub¬ 
blicata sulla rivista N.179.€ 18,60 

Costo del Kit della scheda Triac LX.1206 pubbli¬ 
cata sulla rivista N.180.€ 18,60 

I prezzi riportati sono compresi di IVA, ma non del¬ 
le spese postali che verranno addebitate solo a chi 
richiederà il materiale in contrassegno. 















In questo articolo spieghiamo in maniera dettagliata la direttiva .BYTE, 
usata per la definizione di dati nell’area del programma, e le direttive 
.EQU e .SET, che servono per la definizione delle costanti simboliche. 


LA DIRETTIVA chiamata .BYTE 

La direttiva .byte viene utilizzata per definire in Pro¬ 
gram Space una successione di bytes contenenti 
valori binari ai quali si possono associare eventuali 

Etichette. 

Ogni tentativo di inserire questa direttiva nella Da¬ 
ta Space darà un errore in Compilazione. 

Come per le direttive .ascii e .asciz, i valori defi¬ 
niti in Program Space non sono modificabili du¬ 
rante il corso del programma. 

Per utilizzare i valori definiti con la direttiva .byte 
bisogna prima caricarli in Data Rom Window uti¬ 
lizzando le stesse modalità e gli stessi accorgimenti 
già spiegati nel capitolo riguardante la direttiva 
.w_on (vedi rivista N.190). 

In fase di stesura del programma bisogna attener¬ 
si a quanto riportato nel paragrafo riguardante la 
direttiva .block (vedi rivista N.190). 

L’utilizzo della direttiva .byte ci permette di defini¬ 
re una notevole quantità di valori binari in Program 


Space senza riempire inutilmente l’area di Data 
Space che è di soli 60 bytes, che potrà così es¬ 
sere utilizzata per la dichiarazione delle Variabili 
del programma tramite la direttiva .def. 

Il formato logico della direttiva .byte è il seguente: 

[etichetta] .byte espressi,espress] 

Nota: gli operandi posti fra parentesi quadre so¬ 
no opzionali quindi possono essere omessi. 

[etichetta] = va inserito il nome dell’etichetta che 
vogliamo associare alla locazione di Program Spa¬ 
ce del 1 ° valore definito. Questo nome è opziona¬ 
le quindi può essere omesso. 

espressi,espress] = possono essere uno o più va¬ 
lori espressi in Decimale, Binario o Esadecimale 
separati ognuno da una virgola e non devono mai 
superare la capacità di 8 bits; oppure possono es¬ 
sere delle espressioni (vedi rivista N.189) il cui ri¬ 
sultato finale non deve comunque mai superare 












































































la capacità di 8 bits, che corrisponde ad un valo¬ 
re di 255. 

L’impiego della direttiva .byte risulta particolar¬ 
mente utile per effettuare conversioni, trasposizio¬ 
ni, sostituzioni di valori o per realizzare delle tabelle 
di comparazione. 

1 0 Esempio 

Con questo esempio vi insegniamo ad utilizzare i 
numeri decimali - esadecimali - binari o le e- 
spressioni per definire una serie di tabelle in Pro¬ 
gram Space. 

Poiché l’esempio è stato definito correttamente, in 
fase di Compilazione non si presenteranno errori. 


elisto 

.def 

086h 

costan 

.set 

025h 

stepOI 

.equ 

020h 


.block 

64-$%64 

tabvall 

.byte 

10,15,18,23,45,78,109 

tabval2 

.byte 

01 Oh,015h,018h,023h 

tabval3 

.byte 

001 OOOOOb,01010111b 

tabval4 

.byte 

costan*2,elisto+10 

tabva!5 

.byte 

stepOI +18,stepOI +31 



Fig.1 Semplificando possiamo definire le di¬ 
rettive come disposizioni generali atte a fis¬ 
sare le caratteristiche di fondo che neces¬ 
sitano al programma. Ad esempio: defini¬ 
zione di dati, variabili, macro, costanti sim¬ 
boliche, abilitazione dell’area di memoria 
Data Rom Window, ecc. Perciò, come le i- 
struzioni eseguibili, vengono compilate, ma 
non generano una opcode, cioè un codice 
operativo eseguibile. 


Il significato di queste istruzioni è il seguente: 

elisto .def 086h = definisce la variabile elisto 
all’indirizzo di memoria 086h di Data Space. 

costan .set 025h = associa il valore 025h alla 
etichetta costan senza occupare nessuna aera di 

Program Space. 

stepOI .equ 020h = associa il valore 020h all’e¬ 
tichetta stepOI senza occupare nessuna aera di 

Program Space. 

.block 64-$%64 = questa funzione è stata già 
spiegata nelle riviste N.189 e N.190. 

tabvall .byte 10,15,18,23,45,78,109 = definisce 
in un indirizzo di memoria di Program Space una 
sequenza di 7 bytes contenenti i valori decimali 
sopra riportati ed associa al primo byte l’etichetta 
tabvall. Poiché i numeri separati dalle virgole non 
superano 255 il compilatore non segnalerà errore. 

tabval2 .byte 010h,015h,018h,023h = definisce 
in un indirizzo di memoria di Program Space una 
sequenza di 4 bytes contenenti i valori esadeci¬ 
mali sopra riportati ed associa al primo byte l’eti¬ 
chetta tabval2. 

Poiché i valori separati dalle virgole non supera¬ 
no OFFh (che equivale a 255 decimale) il compila¬ 
tore non segnalerà nessun errore. 

tabval3 .byte 001 OOOOOb,01010111 b = definisce 
in un indirizzo di memoria di Program Space una 
sequenza di 2 bytes contenenti i valori binari so¬ 
pra riportati ed associa al primo byte l’etichetta tab- 
val3. Poiché i valori separati dalle virgole non su¬ 
perano millllb (che equivale a 255 decimale) 
il compilatore non segnalerà nessun errore. 

tabval4 .byte costan*2,elisto+10 = definisce in 
un indirizzo di memoria di Program Space una se¬ 
quenza di 2 bytes contenenti il valore risultante dal¬ 
le espressioni costan*2 ed elisto+10. 

Poiché costan è stato definito 025h, moltiplican¬ 
dolo per 2 otteniamo 04Ah. 

Infatti 025h corrisponde al numero decimale 37, 
che moltiplicato per 2 da 74, che corrisponde al nu¬ 
mero esadecimale 04Ah. 

Poiché elisto è stato definito 086h, che convertito 
in decimale corrisponde al valore decimale 134, 
sommando a questo 10 otteniamo 144, che corri¬ 
sponde al numero esadecimale 090h. 

Poiché entrambi i numeri non superano 255 deci¬ 
male o OFFh esadecimale il compilatore non se¬ 
gnalerà nessun errore. 









































tabval5 .byte step01+18,step01+31 = definisce 
in un indirizzo di memoria di Program Space una 
sequenza di 2 bytes contenenti il valore risultante 
dalle espressioni step01+18 e step01+31. 

Poiché stepOI è stato definito 020h, che converti¬ 
to in decimale corrisponde al valore decimale 32, 
sommando a questo 18 e 31 otteniamo: 

32 + 18 = 50 corrispondente a 032h 
32 + 31 = 63 corrispondente a 03Fh 

Una volta compilate, le tabelle si troveranno me¬ 
morizzate una di seguito all’altra in Program Spa¬ 
ce ed occuperanno un totale di 17 bytes: 

7 bytes per tabvall 
4 bytes per tabval2 
2 bytes per tabval3 
2 bytes per tabval4 
2 bytes per tabval5 

Per utilizzarle dovete procedere come già spiega¬ 
to nella Rivista N.190, al capitolo relativo alla di¬ 
rettiva .w_on. 

2° Esempio 

In questo esempio abbiamo inserito un errore che 
verrà segnalato in fase di Compilazione. 


elisto 

.def 

086h 

costan 

.set 

025h 

stepOI 

.equ 

$+20 


.block 

64-$%64 

tabvall 

.byte 

10,15,18,23,45,78,109 

tabval2 

.byte 

01 Oh,015h,018h,023h 

tabval3 

.byte 

00100000b,01010111 b 

tabval4 

.byte 

costan*2,elisto+10 

tabva!5 

.byte 

stepOI +18,stepOI +31 


La 3° riga dell’esempio precedente era: 

stepOI .equ 020h 

In questo secondo esempio è stata sostituita con: 

stepOI .equ $+20 

Nel capitolo riguardante le espressioni abbiamo 
detto che il Compilatore sostituisce al simbolo $ il 
valore del Program Counter Relativo. Ammesso 
quindi che nella Compilazione la definizione: 

stepOI .equ $+20 

venga a trovarsi nella locazione di memoria Pro¬ 
gram Space 0A13h, che corrisponde al numero 


decimale 2.579, quando il compilatore andrà ad e- 
seguire l’ultima istruzione, cioè: 

tabval5 .byte stepOI+18,stepOI+31 

segnalerà subito questo errore: 

Error on (8) bits Overflow 

Infatti la Costante Simbolica stepOI che equivale 
a 2.579 decimale supera già il massimo consenti¬ 
to di 255 decimale quindi non riesce a sommare 
come richiesto stepOI+18,stepOI+31. 

Se l’ultima istruzione fosse una sottrazione: 

tabval5 .byte stepOI-2360,stepOI-2500 

il compilatore eseguirebbe correttamente questa i- 
struzione senza segnalare nessun errore, perché 
il risultato delle sottrazioni non supera 255, infatti: 

2.579-2.360 = 219 (ODBh) 

2.579 - 2.500 = 79 (04Fh) 

Poiché durante la simulazione sul monitor appaio¬ 
no sempre dei valori espressi in esadecimali, per 
evitare errori vi consigliamo di consultare le Tabelle 
riportate a pag.381 del nostro volume intitolato 

Nuova Elettronica HANDBOOK. 


LA DIRETTIVA chiamata .EQU 

La direttiva .equ viene utilizzata per associare un 
valore numerico, che può essere ricavato anche 
dal risultato di una espressione, ad una Etichet¬ 
ta senza sprecare nessun byte di memoria del mi- 
cro e questo la rende molto interessante. 

Usando l’Etichetta in sostituzione di valori anoni¬ 
mi viene facilitata la lettura ed anche l’interpreta¬ 
zione di un programma sorgente (.asm), persino a 
distanza di mesi dalla sua compilazione. 

La direttiva .equ deve essere inserita sempre pri¬ 
ma di quella istruzione o di quella routine che uti¬ 
lizza l’Etichetta. 

Non è possibile definire la stessa Etichetta più di 
una volta, mentre è possibile associare Etichette 
diverse allo stesso valore. 

Il formato logico della direttiva .equ è il seguente: 

[etichetta] .equ [operando] 

[etichetta] = va inserito il nome dell’etichetta da as¬ 
sociare al valore numerico definito nell’operando. 


[operando] = va inserito il valore numerico o il ri¬ 
sultato di una espressione da associare all’eti¬ 
chetta. Questo numero, che può essere espresso 
in esadecimale, binario o decimale non deve mai 
superare la capacità di 2 bytes vale a dire: 

FFFFh in esadecimale 
1111111111111111b in binario 
65535 in decimale 

Per chiarire eventuali dubbi sull’uso della direttiva 
.equ vi proponiamo alcuni semplici esempi. 

1 ° Esempio 

Con questo esempio vi facciamo vedere come la 
direttiva .equ faciliti la lettura del programma: 


scrivi 

.equ 

014h 

routOO 

Idi 

a,scrivi 


cali 

maiusc 

routOI 

Idi 

a,scrivi 


cali 

minusc 

rout02 

Idi 

a,scrivi 


cali 

corsivo 


Nella prima istruzione l’etichetta scrivi è stata as¬ 
sociata al valore 014h, che equivale al numero de¬ 
cimale 20. 

Le tre routine routOO, routOI, rout02 caricano, per 
prima cosa, nell’accumulatore “a” il valore asso¬ 
ciato all’etichetta scrivi, poi eseguono le subrou¬ 
tine chiamate maiusc, minusc, corsivo. 

Queste subroutine potrebbero risultare utili per far 
apparire sul monitor solo 20 caratteri (014h) in 
maiuscolo oppure in minuscolo o corsivo. 

In pratica noi abbiamo scritto: 

scrivi .equ 014h 

routOO Idi a,scrivi 

cali maiusc 

ma più semplicemente potevamo scrivere: 

routOO Idi a,014h 

cali maiusc 

Per la logica e l’esecuzione del programma non 
cambia assolutamente nulla, ma in questo secon¬ 
do caso rileggendo il programma a distanza di tem¬ 
po potremmo non ricordare a cosa serve questa i- 
struzione. 

Usando la direttiva .equ invece sapremo subito che 
il valore caricato nell’accumulatore “a“ serve per 
scrivere 20 caratteri sul monitor in maiuscolo. 


Se per qualche motivo volessimo modificare il va¬ 
lore da caricare nell’accumulatore “a” in modo da 
scrivere 30 caratteri anziché 20, sarà sufficiente 
modificare la direttiva come sotto riportato: 

scrivi .equ 01 Eh 

Questa direttiva semplifica notevolmente il nostro 
lavoro perché se nell’esempio riportato le routines 
sono poste una di seguito all’altra e quindi facil¬ 
mente individuabili e modificabili, immaginatevi un 
programma molto più complesso che utilizzi più 
routines situate in punti diversi e distanti tra loro. 
In questo caso si perderebbe tempo a scorrere tut¬ 
to il programma nella ricerca del valore 014h per 
modificarlo in 01 Eh e si potrebbero introdurre in¬ 
volontariamente degli errori. 

2° Esempio 

La direttiva .equ può risultare molto utile quando si 
vogliano associare valori diversi partendo da un 
numero fisso ed utilizzando i simboli matematici 
per fare una somma, una moltiplicazione o una 
sottrazione. 


ritardo 

.equ 

150 

routOI 

Idi 

a,ritardo 


cali 

ritardol 

rout02 

Idi 

a,ritardo+50 


cali 

ritardo2 

rout03 

Idi 

a,ritardo*4 


cali 

ritardo3 

rout04 

Idi 

a,ritardo-83 


cali 

ritardo4 


In questo esempio all’etichetta ritardo è stato as¬ 
sociato il valore fisso 150. 

La routine routOI carica nell’accumulatore “a” il va¬ 
lore associato all’etichetta ritardo, cioè 150, quin¬ 
di esegue la subroutine ritardol. 

La routine rout02 carica nell’accumulatore “a” il va¬ 
lore 150 + 50 = 200, poi esegue la subroutine ri- 
tardo2 con questo numero. 

La routine rout03 carica nell’accumulatore “a” il va¬ 
lore 150 x 4 = 600, poi esegue la subroutine ritar- 
do3 con questo numero. 

La routine rout04 carica nell’accumulatore “a” il va¬ 
lore 150 - 83 = 67, poi esegue la subroutine ritar- 
do4 con questo numero. 

Se per qualche motivo volessimo modificare il va¬ 
lore da caricare nell’accumulatore “a”, così da al- 


lungare o accorciare il ritardo in modo proporzio¬ 
nale, sarebbe sufficiente modificare la sola diretti¬ 
va ritardo .equ con il numero desiderato. 

Avrete notato che in entrambi gli esempi abbiamo 
utilizzato l’istruzione Idi (load immediate) e non Id 
per caricare nell’accumulatore “a” il valore asso¬ 
ciato alle etichette scrivi e ritardo. 

Se avessimo utilizzato Id avremmo caricato nell’ac¬ 
cumulatore “a” il valore memorizzato all’indirizzo 

di memoria 014h e 150 e non il numero 014h e 
150 che a noi serve. 


Nella prima istruzione all’etichetta ritardo viene as¬ 
sociato il valore 150. 

In routOI viene caricato nell’accumulatore “a” il va¬ 
lore associato all’etichetta ritardo cioè 150. 

In rout02 viene caricato nell’accumulatore “a” il ri¬ 
sultato dell’espressione ritardo+15 cioè 165. 

Proseguendo nella stesura del programma abbia¬ 
mo previsto di aver bisogno di una nuova diretti¬ 
va .set associata sempre all’etichetta ritardo, ma 
con un diverso valore che nel nostro esempio è 40. 


LA DIRETTIVA chiamata .SET 

Questa direttiva è simile alla precedente con la so¬ 
la differenza che con .set noi possiamo definire 
aH’interno del programma più Etichette con lo stes¬ 
so nome, ma con associati valori diversi. 

Il formato logico della direttiva .set è il seguente: 

[etichetta] .set [operando] 

[etichetta] = va inserito il nome della etichetta da as¬ 
sociare al valore numerico definito nell’operando. 

[operando] = va inserito il valore numerico o il ri¬ 
sultato di una espressione da associare all’eti¬ 
chetta. Questo numero, che può essere espresso 
in esadecimale, binario o decimale non deve mai 
superare la capacità di 2 bytes, cioè: 


In rout06 viene caricato nell’accumulatore “a” il va¬ 
lore associato all’etichetta ritardo cioè 40 

In rout07 viene caricato nell’accumulatore “a” il ri¬ 
sultato dell’espressione ritardo+40 cioè 80. 

In qualche manuale sull’ST6 abbiamo riscontrato 
un uso errato della direttiva .set dal quale voglia¬ 
mo mettervi in guardia perché, non essendo se¬ 
gnalato dal compilatore, potrebbe mettere in un ma¬ 
re di guai un programmatore poco esperto. 

Vi abbiamo più volte avvisato sul fatto che il Com¬ 
pilatore Assembler non esegue il programma, ma 
lo traduce solamente in codice Intel.Hex, sosti¬ 
tuendo alle istruzioni le relative opcode e agli o- 
perandi i relativi valori o gli indirizzi di memoria, e 
controllando unicamente l’integrità di ogni singola 
istruzione. 


FFFFh in esadecimale 
1111111111111111b in binario 
65535 in decimale 

1 0 Esempio 

Per questo esempio abbiamo scelto due istruzioni 
.set con due diversi valori: 150 e 40. 


ritardo 

.set 

150 

routOI 

Idi 

a,ritardo 


cali 

ritardol 

rout02 

Idi 

a,ritardo+15 


cali 

ritardo2 

seguono 

righe 

del programma, 

ritardo 

.set 

40 

rout06 

Idi 

a,ritardo 


cali 

ritardo6 

rout07 

Idi 

a,ritardo+40 


cali 

ritardo7 


Per spiegarvi gli errori in cui si può involontaria¬ 
mente incappare riscriviamo il nostro precedente 
esempio secondo i consigli dati in alcuni manuali e 
vi spieghiamo dove e perché sono scorretti. 


ritardo 

.set 

150 


cali 

routOI 

ritardo 

.set 

40 


cali 

rout06 

routOI 

Idi 

a,ritardo 


cali 

ritardol 

rout02 

Idi 

a,ritardo+15 


cali 

ritardo2 


ret 


rout06 

Idi 

a,ritardo 


cali 

ritardo6 

rout07 

Idi 

a,ritardo+40 


cali 

ritardo7 


ret 



Le istruzioni relative routOI e rout02 sono state 
raggruppate in un unica subroutine chiamata 



routOI, mentre le istruzioni relative a rout06 e 
rout07 sono raggruppate nella subroutine chiama¬ 
ta rout06. 

Abbiamo quindi posto sotto le due direttive asso¬ 
ciate a ritardo le due rispettive cali. 

Da un punto di vista logico il programma sembra 
corretto, in realtà è completamente sbagliato. 

Per capire il perché analizziamo ciò che avviene 
quando tentiamo di compilarlo. 

Quando il Compilatore incontra la direttiva: 

ritardo .set 150 

la esegue ed associa il valore 150 all’etichetta ri¬ 
tardo, quindi passa alla successiva istruzione: 

cali routOI 

Controlla che sia stata scritta correttamente (non 
cals o catl o altro) e che l’operando routOI sia 
un’etichetta di Program Space esistente. 

Se tutto risulta ok la compila. 

A questo punto però non salta alla subroutine 
routOI (come avviene in esecuzione), ma passa 


semplicemente alla istruzione successiva che nel 
nostro caso è la direttiva: 

ritardo .set 40 

ed associa il valore 40 all’etichetta ritardo. 

Ne consegue che ritardo non vale più 150 ma 40. 

E qui sta l’errore. Infatti quando il Compilatore, pro¬ 
seguendo in sequenza, arriva alle istruzioni della 
subroutine routOI : 


routOI 

Idi 

a,ritardo 


cali 

ritardol 

rout02 

Idi 

a,ritardo+15 


cali 

ritardo2 


ret 



non utilizza il valore 150 come dovrebbe, ma con¬ 
sidera il valore 40 e, di conseguenza, carica nell’ac¬ 
cumulatore “a” questo valore. 

Poiché a questo viene sommato 15, avremo 55 
(40 + 15) anziché 165 (150 + 15). 

Quando in seguito arriverà alle istruzioni relative a 
rout06, le compilerà in modo corretto perché 
nell’accumulatore “a” verrà caricato il valore 40 e, 
come richiesto, avremo 40 + 15 = 55. 


Proseguiamo i nostri articoli esplicativi sul linguaggio di programma¬ 
zione Assembler per i micro ST6 illustrando le Opzioni del compilatore. 


Prima di proseguire con la spiegazione delle di¬ 
rettive dell’assembler per ST6 dobbiamo soffer¬ 
marci sulle opzioni del compilatore assembler. 
Come abbiamo più volte ricordato, durante la com¬ 
pilazione il compilatore assembler genera sem¬ 
pre due file, entrambi con lo stesso nome del pro¬ 
gramma sorgente: uno con estensione .HEX in for¬ 
mato intei eseguibile e l’altro con estensione .DSD 
non eseguibile. 

Il file con estensione .dsd è utile perché contiene 
tutte le informazioni di Debug che verranno poi u- 
tilizzate durante la simulazione del programma. 

Il compilatore assembler è inoltre dotato di una se¬ 
rie di opzioni che, se inserite quando si lancia la 
compilazione, generano, oltre ai due già descritti, 
altri tipi di file che ci mettono a disposizione dati 
supplementari ed ulteriori funzioni di controllo sul 
programma sorgente. 

Supponendo di dover compilare il programma sor¬ 
gente chiamato TESTER e di voler aggiungere le 
opzioni -L e -S dobbiamo digitare: 

ast6 -L -S TESTER.ASM 


Innanzitutto, vi facciamo notare che davanti alla let¬ 
tera che contraddistingue le opzioni, in questo ca¬ 
so L ed S, bisogna sempre inserire il segno -, di¬ 
stanziando inoltre le diverse opzioni da uno spa¬ 
zio. Questo è il solo modo corretto di scrittura. 

Le opzioni del compilatore assembler sono: 

-L -X -M -S -O -E -D -F -W 

Premettiamo che utilizzando una qualsiasi di que¬ 
ste opzioni verrà generata una supplementare e- 
stensione, oltre alle due .hex e .dsd già esistenti. 
Rimanendo nell’esempio sopra riportato, noi avre¬ 
mo un file .LIS ed uno .SYM. 

Di seguito vi spieghiamo a cosa servono le nove 
opzioni sopra riportate. 

OPZIONE -L 

Aggiungendo questa opzione il compilatore gene¬ 
ra un file con lo stesso nome del programma sor¬ 
gente, ma con estensione .LIS al cui interno viene 
memorizzato il listato completo del programma. 



































































In fig.1 riportiamo un esempio del listato del file te- 
ster.lis generato dalla compilazione del program¬ 
ma tester.asm. 

Sulla sinistra troviamo dei valori numerici e sulla 
parte destra le istruzioni del programma in for¬ 
mato simbolico. 

Le istruzioni simboliche sono quelle che abbiamo 
scritto realizzando il programma, quindi non hanno 
bisogno di ulteriori spiegazioni. 

E’ invece importante chiarire il significato dei nu¬ 
meri che appaiono sulla sinistra. 

Poiché ciò che diremo verrà successivamente ri¬ 
preso ed approfondito, ci limitiamo ora a fornirvi u- 
na spiegazione molto condensata. 


Il numero 479 è il numero della riga del listato del 
programma e, generalmente, corrisponde alla riga 
del programma con estensione .asm. 

STY= P00 

Indica in quale numero di sezione/pagina di Pro¬ 
gram Space si trova “memorizzata” l’istruzione do¬ 
po la compilazione. 

Nel nostro esempio l’istruzione verrà memorizza¬ 
ta alla Pagina 0 di Program Space. 

Normalmente le sezioni/pagine sono così siglate: 

Pnn 

Snn 

Wnn 


Per rendere più comprensibile la spiegazione, ab¬ 
biamo aggiunto nella prima riga in alto di fig.1 una 
serie di sigle corrispondenti ai dati incolonnati. 
Ovviamente queste sigle non appaiono mai nei li¬ 
stati. 


Pnn - La lettera P sta per Program Page, cioè Pa¬ 
gina di area di Programma, ed nn è il numero di 
pagina in cui si trova l’istruzione. 

Questa pagina viene generata quando si compila 
in assembler e si vuole ottenere un programma e- 
seguibile in formato .hex. 


Analizziamo ora la prima riga: 


Normalmente una Program Page è di 2 kbytes 
LIST = 479 (2048 bytes) per i micro ST6210 - ST6220 e di 4 


LIST 

STY 

scou 

OPCODE 

ST2 SCO 2 NLEV SNU 

LABEL INSTR 

OPERAND 

COMMENT 

479 

P00 

02DB 

C92C 

P00 02DB 479 

jP 

ciclol 

; salta 

480 




480 




481 




481 

; - 



482 




482 

;= DEFINIZIONE DI 

TABELLE IN PROGRAM S 

483 




483 

;- 



484 




484 




485 




485 

.block 

64-$%64 

; 452 ta 

486 

P00 

0300 


P00 0300 486 

mascOl 


; 453 et 

487 




487 

.ascii 

" VOLT " 

; 454 ca 

488 

P00 

0306 

7E 

P00 0306 488 

.byte 

OllllllOb 

; 

489 

P00 

0307 

20 

P00 0307 489 

. byte 

32,32,32 

; 

490 

P00 

0308 

20 

P00 0308 489 




491 

P00 

0309 

20 

P00 0309 489 




492 

P00 

030A 

7F 

P00 030A 490 

. byte 

Olllllllb 

; 

493 

P00 

030B 


P00 030B 491 

masc02 


; 455 et 

494 




492 

.ascii 

" max5V" 

; 456 ca 

495 




493 




496 




494 

.block 

64-$%64 

; 457 ta 

497 

P00 

0340 


P00 0340 495 

cdgramd 


; 458 et 

498 




496 

.input 

"TB_CGR02.ASM" 

; 459 DI 

— 

SOURCE FILE : 

TB_CGR02.ASM 





499 




1 1 

; + - 



500 




1 2 

; | TB_CGR02 Tabella dei caratteri 

per 

501 




1 3 

; + - 



502 




1 4 

; 



503 

P00 

0340 

00 

P00 0340 1 5 

. byte 

o 

o 

o 

o 

; o 

504 

P00 

0341 

00 

P00 0341 1 5 





Fig.1 Esempio del file tester.lis generato dalla compilazione con l’opzione -L. 










kbytes (4096 bytes) per i micro ST6215- ST6225, 

e corrisponde sempre al numero P00. 

Per i micro da 4 Kbytes esiste la possibilità di sud¬ 
dividere la Program Page in due pagine, ognuna 
di 2 Kbytes, inserendo la direttiva .pp_on nel pro¬ 
gramma. 

In questo caso il compilatore divide l’area in due 
sezioni da 2kbytes cadauna (2048 bytes) ed as¬ 
segna il numero partendo da 0, quindi: 

P00 = parte da 0 e finisce a 7FFh 
POI = parte da 800h e finisce a FFFh 

Nel nostro esempio l’istruzione, una volta compila¬ 
ta, partirà dall’indirizzo di program space che ap¬ 
pare nella terza colonna, sotto la scritta Scou, cioè 
da 02DBh, inserita nella pagina P00. 

Snn - La lettera S sta per Program Section, cioè 
Sezione di area di Programma, ed nn è il nume¬ 
ro di sezione in cui si trova l’istruzione. 

La sezione viene generata quando si compila in as¬ 
sembler un programma rilocabile, vale a dire non 
eseguibile, in formato .obj (vedi opzione -O). 

In questo caso il programma sorgente dovrà con¬ 
tenere la direttiva .section e opzionalmente la di¬ 
rettiva .pp_on. 

Sono previste 33 sezioni di Program Space a par¬ 
tire dalla sezione 0, pertanto inserendo nel pro¬ 
gramma .section 1 , poi .section 2 ecc. il compi¬ 
latore suddivide l’area di program space in 1 op¬ 
pure 2 ecc. sezioni. 

La 33° sezione, che corrisponde alla direttiva .sec¬ 
tion 32, serve solo per inserire le istruzioni inerenti 
alla gestione dei Vettori di Interrupt. 
Normalmente una sezione di Program space è di 

2 kbytes (2048 bytes) per i micro ST6210 - 
ST6220 e di 4 kbytes (4096 bytes) per i micro 
ST6215 - ST6225. 

Per i micro da 4 Kbytes esiste la possibilità di sud¬ 
dividere la Program space in due sezioni di 2 Kby¬ 
tes inserendo la direttiva .pp_on nel programma. 

Wnn - Significa Window Section Number e vie¬ 
ne generata quando si compila un programma che 
contiene la direttiva .window/.windowend. 

Serve quando si utilizza il Linker per assemblare 
più programmi rilocabili (.obj) che contengano o- 
gnuno delle aree di dati definiti in Program Spa¬ 
ce (con .byte .ascii ecc.) e che utilizzino quindi la 
Data Rom Window. 

SCOU = 02DB 

Indica l’indirizzo di Program Space in cui l’istru¬ 
zione viene memorizzata dopo la compilazione. 


Se abbiamo suddiviso il programma in Program 
Section (vedi Snn) o in Window Section (vedi 
Wnn), questo indirizzo corrisponderà all’indirizzo di 
memoria relativo alla sezione o alla finestra. Se 
abbiano suddiviso il programma in Page Section, 
corrisponderà all’indirizzo assoluto di memoria del 
microprocessore. 

Ad esempio, se nel listato leggessimo: 

SOI 0034h 

significa che l’istruzione relativa all’indirizzo 0034h 
si trova nella Sezione 01 di Program Space. 

Se nel listato del nostro programma leggessimo: 

P00 0034h 

significa che l’istruzione relativa all’indirizzo 0034h 
si trova nella Pagina 0 di Program Space. 

OPCODE = C92C 

Il numero C92C è la codifica esadecimale dell’i¬ 
struzione jp ciclol dopo la compilazione del pro¬ 
gramma tester.hex. 

Sulla rivista N.185 trovate l’elenco completo di tut¬ 
te le istruzioni dell’assembler con le relative OP¬ 
CODE e semplici istruzioni per decodificarle. 

ST2= P00 

Come avrete notato, questo numero è equivalente 
a quanto riportato sotto la sigla STY, per cui ri¬ 
mandiamo a quanto già spiegato. 

SC02 = 02DB 

Questo numero è equivalente a quanto riportato 
sotto la sigla SCOU ed anche in questo caso ri¬ 
mandiamo a quanto già detto. 

NLEV SNU 

Sotto la colonna NLEV il compilatore inserisce un 
valore che segnala il livello che ha l’istruzione che 
sta compilando. Se non c’è nessun numero, si¬ 
gnifica che l’istruzione fa parte del programma prin¬ 
cipale (nel nostro esempio tester.asm). 

Se c’è il numero 1 significa che l’istruzione fa par¬ 
te di un programma o di un modulo che a sua vol¬ 
ta viene inserito in fase di compilazione nel pro¬ 
gramma principale. 

Se c’è il numero 2 significa che l’istruzione fa par¬ 
te di un programma o di un modulo che a sua voi- 


ta viene inserito in un altro programma o modulo 
che in fase di compilazione viene inserito nel pro¬ 
gramma principale. 

Sotto la colonna SNU c’è il numero 479, che cor¬ 
risponde al numero di riga che ha l’istruzione nel 
file tester.asm. 

A questo proposito non è inutile ricordare che nel¬ 
la colonna List è riportato il numero della riga del 
listato, cioè del file con estensione .LIS, mentre sot¬ 
to la colonna SNU il numero della riga che ha l’i¬ 
struzione nel programma sorgente (.ASM). 

Questi due numeri non sempre corrispondono: ad 
esempio le righe 489 - 490 - 491 della colonna Li¬ 
st corrispondono alle righe 489 - 489 - 489 della 
colonna SNU. 

Il perché è presto detto: l’istruzione .byte 32,32,32 
è definita nel programma sorgente .asm alla riga 
489, ma siccome definisce 3 bytes, il compilatore 
prosegue nella numerazione per altri due numeri. 

Per questo motivo la riga 492 della colonna List 
corrisponde alla riga 490 della colonna SNU. 

Spostatevi ora in basso, alla riga 498 della colon¬ 
na List, che corrisponde alla direttiva: 

.input “TBCGR02.ASM” 

Quando il compilatore trova la direttiva .input, ca¬ 
rica il file riportato nelle virgolette (nel nostro e- 
sempio “TBCGR02.ASM”) e lo assembla inse¬ 
rendolo all’interno del programma principale e se¬ 
gnalandolo nel listato con la dicitura: 

SOURCE FILE : TB_CGR02.ASM 

Ora ignoriamo le righe 499 fino alla 502, che sono 
dei commenti, e passiamo direttamente alla riga 
503 della colonna List relativa alla direttiva: 

.byte 0,0,0,0 

A proposito di questa direttiva è importante rileva¬ 
re innanzitutto che sotto la colonna NLEV c’è il nu¬ 
mero 1, quindi questa istruzione non è contenuta 
nel programma principale TESTER.ASM, ma nel fi¬ 
le TBCGR02.ASM. 

Inoltre sotto la colonna SNU troviamo il numero 5, 
che ci dice che la direttiva .byte 0,0,0,0 è posi¬ 
zionata nella riga 5 del file TBCGR02.ASM. 

Tutte le istruzioni contraddistinte sotto la colonna 
NLEV con il numero 1 fanno parte del file 


TB_CGR02.ASM, quindi nel caso volessimo mo¬ 
dificarle non dovremmo ricercarle nel programma 
principale TESTER.ASM. 

OPZIONE -X 

Il compilatore genera un file con lo stesso nome 
del programma sorgente, ma con estensione .X, 
contenente l’elenco di tutte le etichette e di tutte 
le variabili del programma e con l’indicazione di 
tutte le righe in cui queste vengono utilizzate. 

Ad esempio nel file tester.x possiamo trovare: 

drw 43* 254 300 

dsend 164 166 168 170 172 185 191 202* 
dvolt 67* 68 375 386 388 404 445 

A sinistra è riportato l’elenco in ordine alfabetico di 
variabili, costanti simboliche ed etichette utiliz¬ 
zate nel programma ed in corrispondenza di ogni 
voce dell’elenco abbiamo una serie di numeri, uno 
dei quali contraddistinto da un asterisco. 

I numeri corrispondono alle righe del programma 
.asm in cui variabili - costanti - etichette vengo¬ 
no utilizzate e sono quelli che poi appaiono sotto 
la colonna LIST del file tester.lis (vedi fig.1). 

II numero seguito da un asterisco (*) ci segnala la 
riga del programma sorgente in cui variabili, co¬ 
stanti ed etichette vengono definite. 

OPZIONE -M 

Genera una mappa della memoria del programma 
compilato e la riporta in coda al listato nel file con 
estensione .LIS (vedi fig.2). 

Come avrete già intuito, quando si usa questa op¬ 
zione deve esserci anche l’opzione -L, altrimenti il 
compilatore segnala errore. 


** SPACE PAGE 0' SECTIOH MAP ** 



nome 

1 type | 

■ i 

slze 

PGO 

0 

1 1 

| TEXT | 

300 

PGO 

1 

| TEXT | 

0 

PGO 

2 

| TEXT | 

1 1 

4 


Ho error detected 
Ho warning 


Fig.2 Mappa della memoria nel file tester.lis. 















La scrittura corretta è: 

ast6 -L -M TESTER. ASM 

Nella parte superiore della mappa appare questa 
scritta: 

** SPACE ‘PAGEO’ SECTION MAP ** 

che significa che la mappa stampata riguarda la 
Program Page 0 (P00), di cui abbiamo già parla¬ 
to nel paragrafo dedicato all’opzione -L. 

Nella colonna name della mappa vengono riporta¬ 
te 3 aree di Program Page 0 con a fianco il tipo di 
istruzioni (text) e l’aera occupata in bytes espres- 


OPZIONE -S 

Genera un file con lo stesso nome del programma, 
ma con estensione .SYM, contenente un elenco 
delle etichette definite in Program Space e delle 
costanti simboliche utilizzate nel programma. 
Digitando: 

ast6 -S TESTER.ASM 

viene generato il file tester.sym. 

Di seguito vi riportiamo qualche riga di esempio del 
file tester.sym: 


sa in esadecimale. 

serout 

EQU 

00966H P 

La Program Page 0 è suddivisa in tre aree di me¬ 

outstart 

EQU 

00090H C 

moria non consecutive, perché all’Interno del pro¬ 

addr_10 

EQU 

00915H P 

gramma tester abbiamo utilizzato la direttiva .org, 

eti 

EQU 

00006H C 

tre volte in punti non consecutivi, per posizionarci 

asci_r 

EQU 

00072H C 

all’interno della Program Space. 

asci w 

EQU 

00077H C 

Più precisamente: 

STOPBITS 

EQU 

00001HC 

PG0_0 è un area di Program Page 0 che contie¬ 

Analizziamo 1 

la prima riga: 

ne 300h bytes di istruzioni in formato eseguibile 
che corrispondono a 768 byte in decimali, 

serout : 

EQU 

00966H P 


PG0_1 è un area di Program Page 0 che contie¬ 
ne 08h bytes di istruzioni in formato eseguibile che 
corrispondono a 8 byte in decimale, 

PG0_2 è un area di Program Page 0 che contie¬ 
ne 04h bytes di istruzioni in formato eseguibile che 
corrispondono a 4 byte in decimale. 

Sommando i numeri decimali abbiamo 


La lettera P indica che serout è un etichetta defi¬ 
nita in Program Space ed il numero che si trova 
dopo EQU, cioè 00966H, è il suo l’indirizzo. 


Nella seconda riga: 

outstart: EQU 


00090H C 


768 + 8 + 4 = 780 in decimale 

Convertendo il risultato in esadecimale otteniamo 
30Ch, che è lo spazio occupato dalle sole istru¬ 
zioni del programma. 

Lo spazio occupato dall’intero programma te- 
ster.asm risulterà maggiore, perché queste tre a- 
ree non sono consecutive l’una all’altra. 


la lettera C indica che outstart è una costante sim¬ 
bolica definita nel programma tramite l’utilizzo del¬ 
la direttiva .set o .equ ed il valore 00090H, indica¬ 
to dopo EQU, è il valore a lei associato. 

Il file tester.sym è di vitale importanza per la fase 
di Debug del programma, perché viene utilizzato, 
assieme al file .dsd, dal software di simulazione 
per rendere “leggibile” il programma da testare. 


Disassembler 


Add Qpcode_Label_line morii c 


SES 

OD 

DS 

FE 

Idi wdog,FEH 

SEE 

03 

CO 

07 

jrr 0,port a,08C5H 

SEE 

13 

CI 

09 

jrs 0,port_b,08CAH 

SCI 

1E 

CI 


set- 0,port b 

SC3 

(Tì 

-=<1 

SC 


jp 08CAH 


SCS 

OE 

CI 


res 0,port b 

SCA 

OD 

DS 

FE 

Idi wdog,FEH 

SCD 

83 

CO 

07 

jrr l,port a,08D7H 

SDO 

93 

CI 

09 

jrs 1,port_b,OSDCH 


Fig.3 Programma compilato senza l’opzione -S. 


Add Qpcode 

SES OD DS FE 
SEE 03 CO 07 
SEE 13 CI 09 
SCI 1E CI 
SC3 A3 SC 


SCS OE CI 
SCA OD DS FE 
SCD S3 CO 07 
SDO 93 CI 09 


Label 

ripeti 


mainO0 


mainai 


Hnemonic _ 

Idi wdog,FEH 
jrr 0,port_a,mainOO 
j r s 0,p ort_b ,. maina1 
aet 0,port_b 
jp mainai 


rea 0,port_b 

Idi wdog,FEH 

jrr 1,port_a,main01 

j r a 1,p ort_b,maina Z 


Fig.4 Programma compilato con l’opzione -S. 
















Se in fase di simulazione venisse caricato il solo 
programma in formato eseguibile, cioè il program¬ 
ma tester.hex che contiene le sole opcode, anche 
i programmatori molto esperti avrebbero parecchie 
difficoltà di lettura. 

Utilizzando il file tester.sym, il software di simula¬ 
zione trasforma le opcode eseguibili in istruzioni 
leggibili, rendendo la fase di Debug molto più sem¬ 
plice. 

In fig.3 potete vedere l’esempio di un programma 
di simulazione durante la fase di Debug del pro¬ 
gramma tester.asm che è stato compilato senza 
inserire l’opzione -S. 

In fig.4 riportiamo lo stesso programma compilato 
con l’opzione -S. 

Come potete vedere, mancando il file tester.sym 
in fig.3 non appaiono tutte le etichette di salto che 
sono invece presenti nella fig.4. 

OPZIONE -O 

Questa opzione serve per generare un programma 
rilocabile non eseguibile in formato .OBJ. 

Usando questa opzione non vengono generati i fi¬ 
le .hex, .dsd e .sym. 


Questa opzione si utilizza quando si devono com¬ 
pilare programmi contenenti delle macroroutine, 
che possiamo unire in seguito ad altri programmi 
tramite il Linker per ottenere un unico programma 
eseguibile. 

In pratica creiamo delle librerie utilizzabili ogni¬ 
qualvolta ne avremo bisogno. 

Ma che cosa significa programma rilocabile? 
Quando si assembla un programma, il compilato¬ 
re assegna ad ogni variabile un indirizzo di Data 
Space e ad ogni istruzione un indirizzo di Pro¬ 
gram Space. 

Se si è compilato un programma eseguibile, che 
come sappiamo genera i due file .hex e .dsd, gli 
indirizzi di Program Space e Data Space assegnati 
dal compilatore si posizionano all’interno del mi¬ 
croprocessore esattamente nel punto di memoria 
indicato (indirizzamento assoluto). 

Se si è compilato un programma rilocabile trami¬ 
te l’opzione -O, si ottiene un file .obj e alle sue va¬ 
riabili ed istruzioni viene assegnato un indirizzo 
di memoria (indirizzamento relativo a questo .obj). 
Unendo, tramite il Linker, uno o più programmi ri- 
locabili otteniamo un file eseguibile che può es- 


LIST 

STY 

scou 

OPCODE 

ST2 

SCO2 HLEV 

SHU 

LABEL 

IliSTR 

OPERHHD 

460 






43 

**************************** 

461 






49 


.section 1 

462 

301 

0000 


301 

0000 

50 

serin 



463 

301 

0000 

0D309S 

301 

0000 

51 


Idi 

x,in_start 

464 

301 

0003 


301 

0003 

52 

get 



465 

301 

0003 

0DD3FF 

301 

0003 

53 


Idi 

wdr,Offh 

466 

301 

0006 

A101 

SOI 

0006 

54 


cali 

get_byte 

467 

301 

0003 

CED4 

SOI 

0003 

55 


ras 

psi,tscr 


Fig.5 II programma rilocabile subjn.obj generato dall’opzione -O. 


LIST 

STY 

scou 

OPCODE 

ST2 

SC02 HLEV 

SHU 

LABEL IHSTR 

OPERAHD 

460 






48 

■ ************************ 
f 

461 






49 

.section 1 

462 

POI 

OSCA 


301 

0000 

50 

serin 


463 

POI 

09CA 

0D8098 

SOI 

0000 

51 

Idi 

x,in start 

464 

POI 

09CD 


SOI 

0003 

52 

get 


465 

POI 

09CD 

0DD8FF 

SOI 

0003 

53 

Idi 

udr,Of f h 

466 

POI 

09D0 

419E 

SOI 

0006 

54 

cali 

get byte 

467 

POI 

09D2 

CBD4 

SOI 

0008 

55 

res 

psi,tscr 


Fig.6 Lo stesso programma di fig.5 dopo l’esecuzione Linker. 















sere memorizzato nel micro, ma nell’unione il 
Linker assegnerà ad ogni istruzione ed ad ogni 
variabile un nuovo indirizzo di memoria. 

Come esempio in fig.5 riportiamo alcune istruzioni 
del listato del programma subjn.asm compilato 
con l’opzione -O. 

Come potete vedere alla riga 463 troviamo: 

SOI 0000 0D8098 SOI 0000 51 

corrispondente all’istruzione: 

Idi x,in_start 

SOI 0000 è l’indirizzo di Program Section dell’i¬ 
struzione, 

0D8098 è l’opcode eseguibile dell’istruzione, 

51 è il numero di riga di questa istruzione nel pro¬ 
gramma sorgente. 

In pratica l’istruzione Idi x,in_start viene memo¬ 
rizzata nel byte 0 di Program Section 1. 

Se tramite il Linker uniamo questo programma ad 
un altro programma .obj, ad esempio reg_r.obj, ot¬ 
teniamo un programma eseguibile al quale va as¬ 
segnato un nome, ad esempio pluto.hex. 

Il comando di Linker utilizzato per eseguire que¬ 
sta unione è il seguente: 

Lst6 -I -O PLUTO.HEX REG_R.OBJ SUBJN.OBJ 

A seguito di questa unione viene generato il pro¬ 
gramma eseguibile pluto.hex, composto dai due 
programmi reg_r.obj e subjn.obj. 

In fig.6 riportiamo lo stesso listato di subjn.obj 
dopo l’esecuzione Linker. 

Come potete vedere, alla riga 463 troviamo ora: 

POI 09CA 0D8098 SOI 0000 51 

POI 09CA è l’indirizzo di Program Page dove vie¬ 
ne ora definitivamente memorizzata l’istruzione e 
0D8098 è l’opcode eseguibile dell’istruzione. 

Una volta linkata, questa istruzione risulta memo¬ 
rizzata definitivamente all’indirizzo 09CAh di Pro¬ 
gram Space del programma pluto.hex. 

Vi abbiamo “dimostrato” che unendo i due file con 
estensione .obj vengono modificati gli indirizzi del¬ 
le variabili e delle opcode. 

Se volete un’ulteriore conferma, confrontate il va¬ 
lore che si trova sotto la colonna OPCODE in cor¬ 
rispondenza dell’istruzione cali get_byte di fig.5 
con il rispettivo valore riportato in fig.6. 


Il valore dell’opcode che prima del Linker era 
Al01 h è diventato 419Eh. 

Infatti l’etichetta get_byte che prima del linker si 
trovava all’indirizzo relativo di Program Section 
014h, dopo il Linker è stata memorizzata all’indi¬ 
rizzo di Program Space 9E4h. 

OPZIONE -E 

Se compilando il file TESTER.ASM digitiamo: 

ast6 -E TESTER.ASM 

viene generato un file con lo stesso nome del pro¬ 
gramma, ma con estensione .ERR. 

Questo file contiene l’elenco di tutti gli errori ri¬ 
scontrati durante la compilazione assembler e ri¬ 
porta sul monitor solo l’indicazione (vedi fig.7): 

nnn error detected 
No object created 

Il file con gli errori riscontrarti può essere visualiz¬ 
zato e stampato con un qualsiasi Editor. 

Questa opzione ci offre molti vantaggi, perché se 
nel programma vi sono molti errori, è sicuramente 
molto utile averne a disposizione una stampa, an¬ 
ziché dover consultare su video i messaggi di er¬ 
rore con il rischio che qualcuno sfugga. 

In fig.8 riportiamo il listato ottenuto con un norma¬ 
le file tester.err. 

Con questo listato ci sarà possibile modificare e 
correggere le istruzioni segnalate in modo da otte¬ 
nere una compilazione corretta. 

OPZIONE -D 

Se non diversamente specificato, quando si com¬ 
pila un programma ogni byte di area Program Spa¬ 
ce non utilizzata viene riempito dal compilatore con 
il valore OFFh. 

Utilizzando l’opzione -D seguita da un valore nu¬ 
merico possiamo riempire i byte non utilizzati con 
un determinato valore. 









Ad esempio, scrivendo: 

ast6 -D09 TESTER.ASM 

la parte di Program Space non utilizzata viene 
riempita con il valore 09. 

All’atto pratico questa opzione può servire come 
chiave di controllo. 

Tenete presente che il numero riportato dopo la D 
deve essere esadecimale, diversamente verrà se¬ 
gnalato errore. Ad esempio, per inserire il numero 
174 dobbiamo digitare -DAE. 

OPZIONE -F 

Inserendo questa opzione, se si verificano errori 
nella compilazione, nel messaggio di errore viene 
visualizzato l’intero Pathname del file contenente 
il programma sorgente. 

Per inserire l’opzione -F basta digitare: 

ast6 -F TESTER.ASM 

Sapere il Pathname completo del programma che 
ha dato errore è utile nel caso esistano più versio¬ 
ni dello stesso memorizzate in directory diverse o 
su floppy come copie di sicurezza. 

OPZIONE -W 

In fase di compilazione possono essere segnalati 
dal compilatore due diversi tipi di errori: 

WARNING oppure ERROR 

La scritta ERROR indica che l’errore è molto gra¬ 
ve, tale da impedire la compilazione in assembler 
del programma. In questo caso è necessario inter¬ 
venire nel programma e correggere gli errori se¬ 
gnalati prima di ricompilare il programma. 

La scritta WARNING indica che l’errore riscontra¬ 
to non è grave, quindi la compilazione in assem¬ 
bler riesce a proseguire. 


Nel segnalare questo tipo di errore il compilatore 
gli assegna un numero, 0, 1 o 2 seguito dal sim¬ 
bolo >, che rappresenta la tipologia dell’errore. 

E’ comunque consigliabile andare a verificare, al¬ 
meno la prima volta che si compila il programma, 
anche questo tipo di errore, perché potrebbe com¬ 
promettere la corretta esecuzione del programma. 
In fase di compilazione è possibile comunicare al 
compilatore quale tipologia di errore warning vo¬ 
gliamo che sia segnalata. 

Ad esempio se scriviamo: 

ast6 -W1 TESTER.ASM 

verranno segnalati solo gli errori di tipologia 0 ed 
1, ma non di tipologia 2. 

Nella terza riga di fig.8 è segnalato un errore tipo 
warning con l’indicazione 1> e la spiegazione 
dell’errore riscontrato. 

Potendo differenziare tre diverse tipologie di erro¬ 
re warning, possiamo compilare più volte il pro¬ 
gramma sorgente dando ogni volta l’opzione -W 
con un diverso numero. 

In questo modo potremo controllare prima tutti gli 
errori -W0, poi i -W1 ed infine i -W2. 

CONCLUSIONE 

Lanciando la compilazione potete caricare più op¬ 
zioni in una volta, ma tenete presente che alcune 
opzioni non sono compatibili tra loro. 

- Se usate l’opzione -O non dovrete usare la -D, 
comunque se la inserite verrà ignorata. 

- Se usate l’opzione -W non dovrete usare la -S, 
comunque se la inserite verrà ignorata. 

- Se usate l’opzione -D non potete inserire nel pro¬ 
gramma la direttiva .pp_on. 

- Se usate l’opzione -M dovrete usare sempre an¬ 
che la -L; se non la inserite il compilatore segna¬ 
lerà errore. 


Error C:\ST6\tester.asm 60 : < 77 )operand maj not referente program space spiti 
Error C:\ST6\tester.asm 110 : (20)operand enpectedi 3-bit number 
Warning C:\ST6\tester.asm 113:(91) 1> simfaol declared esternai bui unused 
Error C:\ST6\tester.asm 123: (-1) syntax error 

Error C:\ST6\tester.asm 12 3 :( 110 ) data addresses must be in thè range [0..0ffh] 
Error C:\ST6\tester.asm 126 : (67)undefined mero : sut 
Error C:\ST6\tester.asm 113 :< 10 6 ) unde f ined syutool: port_d 


Fig.8 Esempio di come vengono segnalati gli errori con le opzioni -E e -W. 







Continuiamo anche in questo numero le nostre lezioni teorico-pratiche 
sulla programmazione dei micro ST6. Infatti, contrariamente a quanto 
supponevamo, i nostri lettori, unitamente a molti Istituti professionali 
e tecnici e a parecchie piccole e medie Industrie, li aspettano con im¬ 
pazienza perché li trovano molto istruttivi e interessanti. 


Dopo l’ultimo articolo dedicato alle opzioni del lin¬ 
guaggio Assembler, avremmo dovuto continuare 
con le lezioni sulle direttive per poi arrivare al 
linker e completare così la conoscenza di questo 
linguaggio di programmazione. 

Ma per venire incontro ai molti lettori che ci hanno 
scritto per avere spiegazioni più dettagliate sulle 
memorie Ram-EEprom dei micro ST6260 e 
ST6265 (vedi nella rivista N.192 l’articolo “Bus per 
testare le funzioni Pwm e EEprom”), in questo ar¬ 
ticolo tratteremo queste memorie. 

Prima di entrare nell’argomento vogliamo parlarvi 
dei registri chiamati Write Only e Write Only Bits, 

perché se gestiti in maniera non corretta posso¬ 
no provocare anomalie anche gravi durante l’ese¬ 
cuzione dei programmi. 

I REGISTRI 

Con il termine generico di registri si intende una 
serie di indirizzi di memoria Ram Data Space, che 
il micro utilizza per svolgere particolari funzioni. 


Per ogni diversa funzione è previsto un apposito 
registro, che si trova in una ben determinata lo¬ 
cazione di memoria Data Space. Per facilitare la 
stesura del programma, ad ogni locazione di me¬ 
moria viene associata un’etichetta. 

Per quanto riguarda i micro della famiglia ST6 da 
noi finora presi in esame, cioè gli ST6210-15, 
ST6220-25 e gli ST6260-65, nelle Tabelle N.1 e 
N.2 elenchiamo le definizioni di tutti i registri ed il 
loro indirizzo di Data Space. Per completezza ab¬ 
biamo riportato a fianco di ogni registro l’etichetta 
da noi utilizzata nei nostri programmi. 

Registri WRITE ONLY 

Nelle lezioni sul linguaggio di programmazione per 
gli ST6 abbiamo più volte ripetuto che le istruzio¬ 
ni SET - RES - JRS - JRR consentono di acce¬ 
dere al singolo bit di una variabile o di un regi¬ 
stro per settario a 0 o a 1 o per interrogare il suo 
stato. 

Se queste istruzioni vengono utilizzate per modifi¬ 
care i singoli bits dei registri Write Only possono 


































































TABELLA N.2 


provocare malfunzionamenti del programma, ai 
quali è difficile risalire. 

Infatti, essendo istruzioni formalmente corrette, in 
fase di compilazione il Compilatore Assembler non 
segnala nessuna anomalia o errore. 


Non solo, anche testando il programma con i più 
diffusi software di simulazione non viene segnala¬ 
ta nessuna anomalia, perché il settaggio del sin¬ 
golo bit viene accettato ed eseguito correttamente. 
Quando però inseriamo il micro sulla sua scheda 
di utilizzo, il circuito non funziona e a questo pun¬ 
to diventa difficile capire perché il micro non ese¬ 
gue le istruzioni per cui è stato programmato. 


TABELLA N.1 


Locazioni dei registri dei micro ST6210-15-20-25 


Data Ram area 

etichetta 

locazione 

X register 

X 

080h 

Y register 

y 

081 h 

V register 

V 

082h 

W register 

w 

083h 

port A data register 

port_a 

OCOh 

port B data register 

port_b 

OClh 

port C data register 

port_c 

0C2h 




port A direction register 

pdir_a 

0C4h 

port B direction register 

pdir_b 

0C5h 

port C direction register 

pdir_c 

0C6h 

Interrupt Option register 

ior 

0C8h 

Data Rom Window register 

drw 

0C9h 




port A option register 

pop_a 

OCCh 

port B option register 

pop_b 

OCDh 

port C option register 

pop_c 

OCEh 

A/D data register 

addr 

ODOh 

A/D control register 

adcr 

ODIh 




Timer Prescaler register 

psc 

0D2h 

Timer counter register 

ter 

0D3h 

Timer status control register 

tscr 

0D4h 

Watchdog register 

wdog 

0D8h 

Accumulator 

a 

OFFh 


Nota: ricordiamo che nei micro ST6210-20 non è 
presente le porta C, di conseguenza i registri 
port_C - pdir_C e pop_C non sono utilizzabili. 

I registri segnalati in negativo sono Write Only Re- 
gister, cioè registri di sola scrittura. 


Locazione dei registri nei micro ST6260-65 


Data Ram area 

etichetta 

locazione 

X register 

Y register 

V register 

W register 

X 

y 

V 

w 

080h 

081 h 

082h 

083h 




port A data register 
port B data register 
port C data register 

port_a 

port_b 

port_c 

OCOh 

OClh 

0C2h 




port A direction register 
port B direction register 
port C direction register 

pdir_a 

pdir_b 

pdir_c 

0C4h 

0C5h 

0C6h 




Interrupt Option register 

Data Rom Window register 

ior 

drw 

EH 




port A option register 
port B option register 
port C option register 

pop_a 

pop_b 

pop__c 

OCCh 

OCDh 

OCEh 




A/D data register 

A/D control register 

addr 

adcr 

ODOh 

ODIh 




Timer Prescaler register 

Timer counter register 

Timer status control register 

psc 

ter 

tscr 

0D2h 

0D3h 

0D4h 




AR timer mode control register 1 
AR timer status/control register 2 
AR timer load register 

arme 

arsi 

ars2 

0D5h 

0D6h 

0D7h 




Watchdog register 

wdog 

0D8h 




AR timer reload/capture register 
AR timer compare register 

AR timer load register 

arre 

arcp 

arlr 

0D9h 

ODAh 

ODBh 




Oscillator control register 

ocr 

ODCh 




Miscellaneous 

mis 

ODDh 

SPI data register 

SPI divider register 

SPI mode register 

spda 

spdv 

spmc 

OEOh 

OEIh 

0E2h 




Data Ram/EEprom register 

eedbr 

0E8h 

EEprom control register 

eeer 

OEAh 




Accumulator 

a 

OFFh 


Nota: i registri segnalati in negativo, cioè ior - drw 
- ocr - eedbr, sono Write Only Register. 















































Nessuno ha mai esplicitamente messo in eviden¬ 
za che ai registri Write Only si può accedere e- 
sclusivamente con istruzioni che settano o re- 
settano tutti gli 8 bits contemporaneamente, vale 
a dire con le istruzioni tipo LD - LDI - CLR ecc. 

I registri Write Only comuni a tutti i micro della se¬ 
rie ST6 sono: 


Only dobbiamo riscrivere tutti gli 8 bits utilizzando 
l’istruzione LDI: 

Idi ior,00010000b 

oppure possiamo scrivere: 

Idi ior,16 


Interrupt option register 0C8h (ior) in quanto il numero binario 00010000 corrisponde 

Data rom window register 0C9h (dwr) al numero decimale 16. Se anziché scrivere l’i¬ 

struzione in binario o in decimale volessimo scri- 

Nei micro ST6260-65 abbiamo in più: verla in esadecimale dovremmo modificarla in: 


Oscillator control register ODCh (ocr) 

Data ram/eeprom register 0E8h (eedbr) 

Quindi anche il Data Ram-EEprom register è un 

registro di sola scrittura. 

Per chiarire come vanno utilizzati questi registri fac¬ 
ciamo un esempio molto semplice, ma che ci sem¬ 
bra appropriato. 

Poniamo il caso di voler scrivere la parola IN¬ 
GRESSO, ma per errore scriviamo INGRASSO. 
Se fossimo in un programma di videoscrittura, per 
correggere questo errore basterebbe sostituire la 
lettera A con la lettera E e la parola sarebbe for¬ 
malmente corretta. 

Per i registri di sola scrittura questo non è possi¬ 
bile, perché non possiamo accedere al singolo bit, 
ma solo a tutti gli 8 bits contemporaneamente. 

Nel nostro esempio dovremmo riscrivere l’intera 
parola INGRESSO e non correggere la A con la E. 

Esempio per Interrupt Option Register 


Fig.1 Formato del registro IOR 
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Idi ior,01 Oh 

Esempio per Data Ram/EEprom Register 


Fig.2 Formato del registro EEDBR 
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Per attivare una delle 3 pagine aggiuntive di me¬ 
moria dei micro ST6260-65, dobbiamo configurare 
il registro EEDBR come segue: 


bit 0: settare a 1 per attivare la Eeprom Page 0 

bit 1 : settare a 1 per attivare la Eeprom Page 1 

bit 4: settare a 1 per attivare la Ram Page 2 

In altre parole, essendo anche questo un registro 
Write Only, per attivare la Eeprom Pagel non pos¬ 
siamo scrivere: 

set 1,eedbr 

ma dobbiamo invece scrivere: 

Idi eedbr,0000001 Ob 

Volendo questa istruzione in decimale scriveremo: 


Nella quasi totalità dei programmi, gli interrupt del Idi eedbr,2 

micro sono inizialmente caricati a zero. 

Per disattivare tutti gli interrupt l’istruzione corret- Ancora, per disattivare questa Eeprom Page 1 
ta è la seguente: molti commettono l’errore di scrivere: 


Idi ior,00000000b 


res 1,eedbr 


Per attivare l’interrupt GEN, cioè il bit 4 del regi¬ 
stro ior, verrebbe logico scrivere: 

set 4,ior 

Con questa istruzione il programma non funziona. 
Essendo il registro di Interrupt un registro Write 


invece occorre necessariamente scrivere: 

Idi eedbr,0 

In fase di programmazione dovrete sempre ricor¬ 
darvi di questi piccoli particolari per eliminare i 
problemi che ora potreste riscontrare. 






Registri WRITE ONLY BUS 

Oltre ai registri Write Only, esistono tre registri che 
hanno solamente alcuni bits Write Only. 

Anche questi, se utilizzati in maniera impropria, 
possono creare malfunzionamenti nel programma. 

Il registro Write Only Bits comune ai micro ST6 è: 

A/D converter control register ODIh (adcr) 

Nei micro ST6260-65 abbiamo in più: 

EEprom control register OEAh (eecr) 

AR timer mode control register 0D5h (arme) 


Fig.5 Formato del registro ARMO 
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Nel registro ARMO c’è un solo bit Write Only e 
precisamente il bit 7 siglato TLCD. 

Quando questo bit è settato a 1 ricarica il contato¬ 
re del timer con il valore di base. 

Questo particolare registro è stato trattato nei pro¬ 
grammi di esempio del PWM, nella Rivista N.192. 
Nel dischetto DF.1325 da noi fornito troverete una 
serie di semplici programmi corredati di note coi 
quali sarà semplice capire come usare il PWM. 


In questi registri ci sono dei bits che non possia¬ 
mo mai interrogare con istruzioni tipo JRS e JRR, 
perché, qualunque sia il loro stato logico, ritornano 
sempre il valore 0. 


Fig.3 Formato del registro ADCR 
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In questo registro il Write Only Bit è il 5, che tro¬ 
viamo siglato STA. 

Quando è settato a 1 indica l’inizio della conver¬ 
sione Analogico/Digitale. Se, dopo aver attivato 
l’A/D Converter con l’istruzione: 

Idi adcr,00110000b 

scriviamo: 

jrs 5,adcr,start_c 

il programma non salterà mai a start_c, perché, 
essendo il bit 5 di sola scrittura, e non di lettura, 
non riesce a vederlo settato e quindi il risultato del¬ 
la interrogazione sarà sempre 0. 


Fig.4 Formato del registro EECR 
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Nel registro EECR vi sono tre bits Write Only: 

EEENA bit 0 

EEPAR1 bit 3 

EEOFF bit 6 


Le MEMORIE EEprom e RAM addizionale 

Quando abbiamo presentato il programmatore 
LX.1325 per i micro della serie ST626065 (vedi ri¬ 
vista N.192), ci siamo anche preoccupati di spie¬ 
garvi con semplici esempi la logica del PWM e del¬ 
la memoria EEprom. 

Proprio per questo motivo nel dischetto allegato al 
kit (siglato DF.1325) abbiamo fornito una serie di 
programmi elementari, corredati di note a fianco di 
ogni istruzione, per rendere più comprensibili l’uti¬ 
lizzo del PWM e della memoria EEPROM. 

Data la novità dell’argomento sono giunte in reda¬ 
zione richieste di approfondimento soprattutto 
sull’utilizzo e la gestione della memoria EEprom. 
Per venire incontro a questa esigenza, affrontiamo 
in questo paragrafo le memorie EEprom e RAM 
addizionale dei micro ST6260 e ST6265. 

Nella fig.6 è riportato il diagramma a blocchi dei mi¬ 
cro ST6210-15-20-25, mentre nella fig.7 potete ve¬ 
dere quello relativo ai micro ST6260-65. 
Confrontando le due figure potete notare che i mi¬ 
cro ST6260-65, riportati in fig.7, possiedono in più 
la funzione Autoreload Timer, un SPI (Serial Pe- 
ripheral Interface), una Data Ram di 128 bytes ed 
una Data EEprom di 128 bytes. 

Specifichiamo subito, per evitare equivoci, che la 
DATA RAM dei micro ST6260-65 è data da un ban¬ 
co di memoria RAM aggiuntivo di 64 bytes che, 
sommato ai 64 bytes che tutti i micro della classe 
ST62 possiedono (all’indirizzo 84h-BFh), fa ap¬ 
punto un totale di 128 bytes di RAM. 

Per quanto riguarda invece la memoria EEPROM 
si tratta di due banchi di memoria di 64 bytes. 

I banchi aggiuntivi RAM ed EEPROM vengono con¬ 
venzionalmente definiti “pagine” e possono esse¬ 
re selezionati ed utilizzati solo uno per volta: 


Naturalmente anche per questi bits vale quanto det¬ 
to sopra. Nel prossimo paragrafo spiegheremo l’u¬ 
tilizzo completo di questo registro. 


Eeprom Page 0 corrisponde al primo banco ag¬ 
giuntivo di memoria EEprom, 

Eeprom Page 1 corrisponde al secondo banco ag- 


































giuntivo di memoria EEprom, 

Ram Page 2 corrisponde al banco di memoria RAM 
aggiuntivo. 

Come abbiamo già avuto modo di ricordare, to¬ 
gliendo la tensione di alimentazione al micropro¬ 
cessore, la memoria EEprom mantiene memoriz¬ 
zati i dati in essa contenuti per circa 10 anni e per 
questo motivo si usa molto frequentemente. 

Ciò procura evidentemente dei vantaggi e perciò si 
tende normalmente a sfruttare frequentemente 
questa importante caratteristica. 

Dobbiamo comunque precisare che le memorie 
EEprom non hanno vita infinita, infatti la Casa Co¬ 
struttrice dà una vita media di circa 1.000.000 di ci¬ 
cli di scrittura o cancellazione. 

Inoltre la fase di scrittura in una memoria EEPROM 
richiede una certa frazione di tempo (in condizioni 
ottimali dai 10 ai 20 millisecondi), perché prima di 
registrare un dato viene effettuata la erase, cioè la 
cancellazione dei dati che erano stati in prece¬ 
denza memorizzati. 

La Ram Page 2 non presenta nessun problema in 
fase di gestione, perché, una volta selezionata con 
il registro EEDBR, si può usare come una norma¬ 
le area Data Ram per la gestione delle variabili. 


LE 3 PAGINE di MEMORIA 

Vediamo ora di spiegare come utilizzare in manie¬ 
ra ottimale le tre pagine di memoria aggiuntiva dei 
micro ST6260-65. 

La caratteristica comune a queste 3 pagine di me¬ 
moria è quella di avere una dislocazione paralle¬ 
la, vale a dire che sono poste una sopra l’altra co¬ 
me le pagine di un libro, e ognuna di queste pagi¬ 
ne possiede un’area di 64 bytes che inizia dall’in¬ 
dirizzo di memoria OOOh e termina con l’indirizzo di 
memoria 03Fh. 

Come in un libro per indicare un capitolo dobbia¬ 
mo anche specificare in quale pagina si trova, co¬ 
sì per leggere e per scrivere in queste memorie 
dobbiamo indicare l’indirizzo dei bytes che ci inte¬ 
ressano e la loro pagina (Eeprom o Ram). 

Per effettuare la selezione della pagina di memo¬ 
ria che si vuole utilizzare si usa un registro appo¬ 
sito che noi abbiamo chiamato EEDBR. 

Il Registro EEDBR o Data Ram-EEprom Register 
è, come abbiamo già detto, un registro Write Only 
definito all’indirizzo 0E8h di Data Space. 

Come potete vedere in fig.2, per selezionare le pa¬ 
gine di memoria occorre usare: 

bit 0 per la Eeprom Page 0 
bit 1 per la Eeprom Page 1 
bit 4 per la Ram Page 2 


TEST/Vpp 


NMI 



Vdd Vss OSCin OSCout RESET 


Fig.6 Diagramma a blocchi dei 
microprocessori ST6210-15- 
20-25. Come evidenziato an¬ 
che nella figura, la Port C è 
presente solo nei micro 
ST6215-25. Di conseguenza i 
registri port_C, pdir_C e 
pop_C non sono utilizzabili 
con i micro ST6210-20. 

















































































TEST/Vpp 


NMI 



Vss OSCin OSCout RESET 


Fig.7 Diagramma a blocchi dei 
micro ST6260-65. Rispetto al¬ 
la serie precedente, questi mi¬ 
cro possiedono in più la fun¬ 
zione Autoreload Timer, un 
Serial Peripheral Interface, u- 
na Data Ram di 128 bytes ed 
una Data EEprom di 128 bytes. 


Naturalmente potendo utilizzare una pagina di me¬ 
moria alla volta, non è possibile settare contempo¬ 
raneamente più di un bit e se lo farete il program¬ 
ma segnalerà errore. 

Quindi se scrivete: 

Idi eedbr,011h 

fate un errore perché avete settato contempora¬ 
neamente il bit 0 e il bit 4. 

Infatti 01 Ih corrisponde in binario a 00010001. 

Per selezionare la Ram page 2 dovete settare il 
solo bit 4 scrivendo: 

Idi eedbr,010h 

infatti 01 Oh corrisponde al binario 00010000. 

Con il registro EEDBR siamo quindi in grado di di¬ 
re al programma quale pagina di memoria aggiun¬ 
tiva vogliamo utilizzare. 

Nella stesura del programma è inoltre possibile as¬ 
sociare agli indirizzi di queste pagine delle etichet¬ 
te con l’istruzione .def, tenendo sempre presente 
però che queste etichette identificano un indirizzo 
comune a tutte e tre le pagine. 


Ad esempio se scriviamo: 

pippo .def OOOh 
gatto .def 001 h 

associamo l’etichetta pippo all’indirizzo di memo¬ 
ria OOOh e l’etichetta gatto all’indirizzo 001 h. 
Essendo l’area di memoria comune a tutte e tre le 
pagine, gli indirizzi OOOh e 001 h costituiscono il by¬ 
te 0 e il byte 1 sia della Eeprom Page 0 sia della 
Eeprom Page 1 sia della Ram Page 2. 

Quindi pippo e gatto definiscono il primo ed il se¬ 
condo byte di tutte e tre le pagine. 

Se ora riprendiamo l’istruzione: 

Idi eedbr,010h 

che seleziona la Ram page 2 e successivamente 
scriviamo: 

Id a,pippo 

carichiamo nell’accumulatore “a” il valore corri¬ 
spondente all’etichetta pippo, cioè il valore conte¬ 
nuto nel byte 0 della memoria Ram Page 2. 

Se invece scriviamo: 

Idi eedbr,001h 

Id a,pippo 



























































































selezioniamo la Eeprom Page 0 e carichiamo 
nell’accumulatore “a” il valore contenuto nel byte 
0 di questa memoria. 

Come sempre, queste gestioni richiedono un po’ di 
attenzione nella stesura del programma. 

E’ possibile poi, durante l’esecuzione del program¬ 
ma, “spostarsi” da una pagina all’altra di queste tre 
memorie tenendo però sempre presente che è me¬ 
glio utilizzare e soprattutto scrivere nelle Eeprom 
Page solamente quando effettivamente necessita, 
per “allungare” così la loro vita il più possibile. Con¬ 
viene perciò, dove naturalmente sia fattibile, che il 
programma, una volta che si è posizionato in una 
Eeprom Page, non elabori i dati direttamente lì, ma 
li trasporti in una o più variabili definite nella nor¬ 
male memoria Data RAM. 

Qui sarà possibile elaborarli tranquillamente e so¬ 
lamente quando necessario il programma li riscri¬ 
verà nella Eeprom Page di partenza. 


LA SCRITTURA nella MEMORIA EEPROM 

La fase di scrittura delle Eeprom Page può esse¬ 
re effettuata in due modalità: 

Modalità byte o Byte mode 
Modalità parallela o Parallel Mode 

Nella scrittura in modalità byte i bytes utilizzati dal 
programma vengono scritti uno alla volta all’inter¬ 
no delle Eeprom Page. 

Si tratta di una modalità da utilizzare solo nel caso 
i bytes siano pochissimi o addirittura 1 solo. 

Infatti ogni ciclo di scrittura dura una certa frazione 
di tempo T, tipicamente 10 millisecondi, quindi se 


i bytes sono molti, ad esempio 7, la durata della fa¬ 
se completa di scrittura è data da 7 x T, cioè: 

7 x 10 = 70 millisecondi 

Nella scrittura in modalità parallela invece i bytes 
vengono scritti all’interno delle Eeprom Page con¬ 
temporaneamente, cioè 8 alla volta. 

Con questa modalità si risparmia notevolmente 
tempo, perché la durata della fase di scrittura è di 
un T per tutti gli 8 bytes. 

Il microprocessore è in grado di posizionarsi au¬ 
tomaticamente nel punto in cui vogliamo che abbia 
inizio la registrazione e da quel punto scrive 8 by¬ 
tes per riga. 

Infatti scrivendo in modalità parallela anche se i by¬ 
tes da scrivere nelle Eeprom Page sono minori di 

8 o non sono multipli esatti di 8 (ad esempio 3 o 
15 o 27) vengono sempre scritti a 8 bytes alla vol¬ 
ta per ogni ciclo di scrittura. 

Nella fig.8 è riportata la suddivisione logica delle 
Eeprom Page in “righe” di 8 bytes nel caso di scrit¬ 
tura in modalità parallela. 

Nel caso di 10 bytes servono almeno 2 cicli di 
scrittura; se dovessimo scrivere 64 bytes dovrem¬ 
mo effettuare 8 cicli di scrittura parallela, infatti 64 
bytes : 8 bytes alla volta = 8 cicli. 

Quindi se i 10 bytes da scrivere in Eeprom Page 
iniziassero all’indirizzo 0, basterebbero 2 cicli di T 
per scrivere 10 bytes: i primi 8 bytes con un ciclo 
T e i restanti 2 con un altro ciclo T. 

Ma cosa succede se dobbiamo iniziare a registra¬ 
re i 10 bytes ad esempio dall'Indirizzo 01 Fh, che 
equivale a 31 decimale? 


Byte 

0 1 2 3 4 5 6 7 indirizzo di 

DATA pageo! E i PROM FÌ9- 8 Con la scrittura in modalità 

RIGA 7 

RIGA 6 

RIGA 5 

RIGA 4 

RIGA 3 

RIGA 2 

RIGAI 

RIGAO 









parallela i oytes vengono scrini 
38h-3Fh all’Interno delle Eeprom Page a 8 

30h-37h alla volta - Qui a fianco potete ve- 

dere la suddivisione logica delle 
28h-2Fh Eeprom Page in righe di 8 bytes 

orn, oh, ciascuna. Come spiegato nell’ar- 

20h-27h *■ . , „ _ 

ticolo, per scrivere ad esempio 10 

18h-1 Fh bytes a partire dall’Indirizzo 01 Fh 

(vedi pallini in nero) dovremo da- 

10h-17h re tre istruzioni di scrittura, per- 

08h-0Fh ché i 10 bytes occupano tre righe 

di 8 bytes delle Eeprom Page. 

00h-07h 
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Fig.9 Formato logico del registro EECR definito all’indirizzo OEAh di Data Space. 
Questo registro è adibito alla gestione della scrittura nelle Eeprom Page. 


Come abbiamo detto, il microprocessore, una vol¬ 
ta avviata la procedura di scrittura, si posiziona 
all’indirizzo 01 Fh, che si trova nella terza riga (ve¬ 
di in fig.8) e da qui inizia a scrivere. 

Poiché deve scrivere 8 bytes alla volta in ogni ri¬ 
ga, non gli bastano più 2 T per scrivere 10 bytes, 
ma ne impiega 3, infatti: 

Il primo dei 10 bytes viene scritto con un ciclo di 
scrittura (1 ° T) nella riga che contiene l’indirizzo 
01 Fh da cui vogliamo che parta, cioè la terza. 

Gli altri 8 bytes vengono scritti con un altro ciclo di 
scrittura (2° T) nella quarta riga, arrivando così 
all’Indirizzo 27h. 

L’ultimo dei 10 bytes viene scritto con un terzo ci¬ 
clo di scrittura (3°T) nella quinta riga. 

Dunque nella modalità parallela è necessario che 
il programmatore tenga conto non solo di quanti by¬ 
tes vanno scritti, ma anche della posizione in cui i 
bytes vanno scritti per sapere quante istruzioni di 
scrittura in modalità parallela deve dare. 

Più avanti troverete altri esempi su questa moda¬ 
lità di scrittura, ma ora continuiamo con la spiega¬ 
zione della gestione di queste memorie aggiuntive. 

Risulta oramai evidente infatti che con il solo regi¬ 
stro EEDBR non è possibile gestire la fase di scrit¬ 
tura delle Eeprom Page, perché non possiede nes¬ 
sun bit che permetta di selezionare e gestire que¬ 
ste due modalità di scrittura. 

Adibito a questa funzione c’è un secondo registro, 
che noi abbiamo chiamato EECR. 

Il registro EECR o Eeprom Control Register, si tro¬ 
va definito all’indirizzo OEAh di Data Space. 

Nella fig.9 potete vedere il suo formato, di cui a- 
nalizziamo ora ogni singolo bit. 

Bit 7 non è utilizzato. 

Bit 6, siglato EEOFF, è un bit Write Only e viene 
definito Stand-by Enable bit. 

Quando è settato la memoria EEPROM è disabi¬ 
litata, di conseguenza non è possibile leggere o 
scrivere in questa pagina; quando è resettato la 
EEprom è abilitata. 


Si può utilizzare questa opzione nel caso il pro¬ 
gramma da eseguire non debba usare mai le Ee¬ 
prom Page. 

Attenzione, essendo un bit Write Only non è con¬ 
sigliabile interrogare il suo stato logico. 

Bit 5 è riservato e deve sempre essere a 0. 

Bit 4 è riservato e deve sempre essere a 0. 

Bit 3, siglato EEPAR1, è un bit Write Only defini¬ 
to Parallel Start Bit. 

Quando è settato il micro scrive in modalità paral¬ 
lela 8 bytes adiacenti nelle Eeprom Page 0 o 1 . 
Fintanto che questo bit rimane settato non è pos¬ 
sibile effettuare altre istruzioni di scrittura. 

Quando la fase di scrittura è terminata il micropro¬ 
cessore resetta automaticamente questo bit. 

Bit 2, siglato EEPAR2, è un bit Write Only defini¬ 
to Parallel Mode Enable Bit. 

Questo bit serve solamente per selezionare la mo¬ 
dalità di scrittura. 

Se settato attiva la modalità di scrittura parallela, 
se resettato attiva la modalità byte. 

Quando la fase di scrittura parallela è terminata vie¬ 
ne automaticamente resettato. 

Bit 1, siglato EEBUSY, viene definito EEprom Bu- 
sy bit, cioè bit di EEprom occupata. 

Questo bit viene gestito direttamente dal micro- 
processore che lo setta ogniqualvolta si lancia un 
ciclo di scrittura nelle Eeprom Page e lo resetta 
quando questa fase è terminata. 

La funzione di questo bit è quella di permettere a 
chi scrive i programmi di poter interrogare la fine 
della fase di scrittura, perché fintanto che è in e- 
secuzione non è consigliabile né lanciare un’altra 
fase di scrittura né tantomeno selezionare una di¬ 
versa pagina di memoria. 

Bit 0, siglato EEENA, è un bit Write Only definito 
EEprom Enable Bit. 

Questo bit serve solo per abilitare la modalità scrit¬ 
tura. Solo quando risulta settato è possibile scri¬ 
vere nelle Eeprom Page. Se resettato ogni tenta¬ 
tivo di scrittura sarà ignorato. 














Ora passiamo ad una serie di esempi per comple¬ 
tare e chiarire quanto detto sopra. 

Il primo esempio riguarda la gestione della scrittu¬ 
ra in modalità parallela, il secondo è un esempio 
di scrittura in modalità byte, mentre il terzo è un 
esempio sulla gestione del tempo durante la fase 
di scrittura nella memoria EEprom. 

Per vostra comodità, oltre a spiegare istruzione per 
istruzione, abbiamo riportato l’intero listato di ogni 
esempio nelle figg.10-12. 

ESEMPI 

1 ° Esempio: Scrittura in Modalità Parallela 

Dobbiamo scrivere un programma che all’inizio leg¬ 
ga 14 bytes della Eeprom Page 0 a partire dall’in¬ 
dirizzo 0 e poi li muova in altrettanti bytes della Da¬ 
ta Ram per poterli elaborare. 

Dopodiché li deve scrivere con modalità parallela 
nella Eeprom Page 1 memorizzandoli dall’indiriz¬ 
zo 012h in poi. 

In fig.10 riportiamo il listato del programma di cui 
ora diamo una spiegazione dettagliata. 

Per comodità associamo all’indirizzo 0 l’etichetta 
beepO e all’indirizzo 012h l’etichetta sceepl. 

beepO .def OOOh 
sceepl .def 012h 

A questo punto definiamo tutte le nostre variabili e 
l’indirizzo di memoria Data Ram che ci serve per 
memorizzare i 14 bytes letti da Eeprom Page 0: 

stramx .def 084h 

Dopo la definizione delle porte utilizzate dal pro¬ 
gramma e la gestione degli eventuali interrupt, il 
programma arriverà alla gestione della lettura del¬ 
la Eeprom Page 0. 

Assegniamo quindi innanzitutto l’etichetta leeprO a 
questa fase, poi ricarichiamo il Watchdog: 

leeprO Idi wdog,0ffh 

Ora attiviamo la memoria aggiuntiva EEPROM: 

Idi eecr,0 

e selezioniamo la Eeprom Page 0: 

Idi eedbr,1 

Dopo questa istruzione nell’area di memoria dall’in¬ 
dirizzo OOOh all’indirizzo 03Fh sono contenuti i va¬ 
lori della Eeprom Page 0. 


Siccome sono 14 i bytes da “trasferire” dalla Ee¬ 
prom Page 0 alla Data Ram e da memorizzare a 
partire dall’indirizzo stramx, carichiamo i registri 
necessari. 

Nel registro w carico il numero 14 per effettuare 14 
cicli di “trasferimento”: 

Idi w,14 

Nel registro x carichiamo l’indirizzo di beepO, che 
corrisponde in questo caso al primo byte di Eeprom 
Page 0: 

Idi x,beepO 

Nel registro y carico l’indirizzo di stramx che cor¬ 
risponde alla locazione iniziale di memoria Data 
Ram dove verranno “trasferiti” i 14 bytes: 

Idi y, stramx 

Assegniamo a questa fase l’etichetta ciclor e rica¬ 
rico il Watchdog. 

ciclor Idi wdog,0FFh 

Ora tramite l’accumulatore a trasferiamo i dati da 

Eeprom Page 0 a Data Ram un byte alla volta: 

Id a,(x) 

Id (y),a 

Decrementiamo quindi il registro w di uno: 

dee w 

Quando arriva a zero abbiamo completato il tra¬ 
sferimento dei 14 bytes quindi usciamo da questa 
fase saltando alla etichetta fineep: 

jrz fineep 

Se invece il trasferimento non è stato ancora com¬ 
pletato, ci posizioniamo al byte successivo sia nel¬ 
la Eeprom Page 0 sia nella Data Ram. 

ine x 

ine y 

ed eseguiamo di nuovo il ciclo: 

jp ciclor 

Il trasferimento del contenuto dei 14 bytes ora è 
completato e quindi possiamo per ora disattivare la 
memoria EEPROM: 

Idi eecr,01000000b 



Fig.10 Listato 1 ° 

Esempio. 
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eecr,00001101b 
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1 ,eecr,$ 
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eeer,00000101 b 
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ÌP 
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finwrp 
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eecr,00001101b 


jrs 

1 ,eecr,$ 


Idi 

eecr,0 

Questo esempio riguarda la gestione della 
scrittura in Modalità Parallela. 



Fig.11 

Listato 2° Esempio. 
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Questo esempio riguarda la gestione della 

scrittura in Modalità Byte. Per la prima par¬ 

te del programma, cioè fino all’elaborazio¬ 

ne dei dati nelle routine rou_add, rou_clc e 

rou_str, si può fare riferimento all’esempio 

riportato in fig.10. 
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Questo esempio riguarda la gestione del 
tempo durante la fase di scrittura nelle Ee- 
prom Page. Notate il posizionamento dell’i¬ 
struzione JRS 1 ,EECR,$ con cui si evita che 

qualche comando 

inerente alla memoria 

EEprom venga attivato prima che la fase di 
scrittura sia terminata. 







A questo punto i dati così caricati in Data Ram ven¬ 
gono elaborati da una serie di routines che nel no¬ 
stro esempio sono rou_add, rou_clc e rou_str: 

cali rou_add 

cali rou_clc 

cali rou_str 

Finita questa fase di elaborazione, il programma 
deve memorizzare i valori ottenuti nella Eeprom 
Page 1. Riattiviamo perciò la memoria EEPROM: 

wrieep Idi eecr,0 

e ci posizioniamo nella Eeprom Page 1 : 

Idi eedbr,2 

Ora dall’indirizzo di memoria OOOh a 03Fh sono 
contenuti i dati presenti nella Eeprom Page 1. 
Attiviamo quindi (non eseguiamo ancora) la scrit¬ 
tura in modalità parallela: 

Idi eecr,00000101 b 

Siccome i bytes elaborati da trasferire dalla Data 
Ram alla Eeprom Page 1 sono 14 e vanno me¬ 
morizzati a partire dall’indirizzo sceepl, carichia¬ 
mo i registri necessari. 

Nel registro w carichiamo il numero 14 per effet¬ 
tuare 14 cicli di “trasferimento”: 

Idi w,14 

La scrittura dei 14 bytes deve partire dalla loca¬ 
zione EEprom 012h, che equivale a 18 in deci¬ 
male, quindi dobbiamo iniziare a scrivere dal ter¬ 
zo bytes della terza riga (vedi la suddivisione lo¬ 
gica delle Eeprom Page in fig.8). 

I 14 bytes saranno quindi registrati 6 nella riga 2 
ed i restanti 8 nella riga successiva. 

Carichiamo pertanto il valore 6 nel registro v: 

Idi v,6 

Nel registro x carichiamo l’indirizzo di stramx, che 
corrisponde alla locazione iniziale di memoria Data 
Ram dove verranno “prelevati” i valori dei 14 bytes: 

Idi x,stramx 

Nel registro y carichiamo l’indirizzo di sceepl, che 
corrisponde all’indirizzo di Eeprom Page 1 dove 
verranno “trasferiti” i valori dei 14 bytes: 

Idi y, sceepl 


A questa fase assegniamo l’etichetta eidos e ri¬ 
carichiamo il Watchdog: 

eidos Idi wdog,0FFh 

Ora tramite l’accumulatore a trasferiamo (non scri¬ 
viamo ancora nulla) i dati da Data Ram a Eeprom 
Page 1 un byte alla volta: 

Id a,(x) 

Id (y),a 

e decrementiamo il registro w di uno: 

dee w 

Quando arriva a zero abbiamo completato il tra¬ 
sferimento dei 14 bytes ed usciamo da questa fa¬ 
se saltando alla etichetta finwrp: 

jrz finwrp 

Se invece non è stato ancora completato, ci posi¬ 
zioniamo al bytes successivo sia nella Eeprom Pa¬ 
ge 1 sia nella Data Ram: 

ine x 

ine y 

e decrementiamo il registro v: 

dee v 

jrnz eidos 

Quando arriva a 0 significa che la prima volta ha 
terminato di caricare i 6 bytes, perciò eseguiamo 
il primo ciclo di scrittura e attendiamo che sia ter¬ 
minata la scrittura interrogando il bit 1 EEBUSY: 

Idi eecr,00001101b 

jrs 1 ,eecr,$ 

Riattiviamo quindi la modalità parallela: 

Idi eecr,00000101 b 

perché restano ancora 8 bytes da trasferire. Rica¬ 
richiamo quindi il registro v con questo valore: 

Idi v,8 

e saltiamo all’etichetta eidos: 

jp eidos 

Quando il programma arriva a finwrp è terminato 
il trasferimento dei bytes, pertanto eseguiamo il se- 


condo ciclo di scrittura e attendiamo che sia ter¬ 
minata la scrittura interrogando il bit EEBUSY: 

Idi eecr,00001101b 

jrs 1,eecr,$ 

Finita la fase di scrittura parallela il bit 3 ed il bit 2 
del registro eecr, denominati rispettivamente EE- 
PAR1 e EEPAR2, vengono automaticamente re¬ 
settati, mentre rimane settato solo il bit 0 denomi¬ 
nato EEENA. Non ci rimane dunque che disattiva¬ 
re subito la modalità scrittura per evitare il perico¬ 
lo di sporcare i dati appena scritti. 

Idi eecr,0 

Il perché di questa ultima affermazione lo capirete 
meglio con il secondo esempio. 


2° Esempio: Scrittura in Modalità Byte 

Dobbiamo scrivere un programma che all’inizio leg¬ 
ga 14 bytes della Eeprom Page 0 a partire dall’in¬ 
dirizzo 0 e poi li muova in altrettanti bytes della Da¬ 
ta Ram per poterli elaborare. Dopodiché li deve 
scrivere con modalità byte nella Eeprom Page 1 
memorizzandoli dall’indirizzo 012h in poi. 

Abbiamo volutamente ripetuto il precedente esem¬ 
pio cambiando solamente la modalità di scrittura 
per fare risaltare maggiormente le differenze di ge¬ 
stione delle due modalità di scrittura. 

E’ perciò evidente che la parte iniziale del pro¬ 
gramma è identica al precedente esempio quindi 
ci pare inutile rispiegarvela. 

Iniziamo dunque la spiegazione dal punto in cui si 
inizia a gestire la scrittura nella Eeprom Page 1 e 
cioè dall’istruzione con etichetta wrieep (fig.11). 
Finita questa fase di elaborazione, il programma 
deve memorizzare i valori ottenuti nella Eeprom 
Page 1. Riattiviamo perciò la memoria EEPROM: 

wrieep Idi eecr,0 

e ci posizioniamo nella Eeprom Page 1 : 

Idi eedbr,2 

Ora attiviamo la scrittura in modalità byte: 

Idi eecr,00000001 b 

Siccome i bytes elaborati da trasferire dalla Data 
Ram alla Eeprom Page 1 sono 14 e vanno me¬ 
morizzati a partire dall’Indirizzo sceepl, carichia¬ 
mo i registri necessari. 


Nel registro w carichiamo il numero 14 per effet¬ 
tuare 14 cicli di “trasferimento”: 

Idi w,14 

Nel registro x carichiamo l’indirizzo di stramx, che 
corrisponde alla locazione iniziale di memoria Data 
Ram dove verranno “prelevati” i valori dei 14 bytes: 

Idi x,stramx 

Nel registro y carichiamo l’indirizzo di sceepl, che 
corrisponde all’indirizzo iniziale di Eeprom Page 1 
dove verranno “trasferiti” i valori dei 14 bytes: 

Idi y, sceepl 

A questa fase assegniamo l’etichetta eidos e ri¬ 
carichiamo il Watchdog: 

eidos Idi wdog,0FFh 

Ora tramite l’accumulatore a trasferiamo e scri¬ 
viamo i dati da Data Ram a Eeprom Page 1 un 
byte alla volta: 

Id a,(x) 

Id (y),a 

In questo momento il dato viene scritto nella Ee¬ 
prom Page 1. 

Ora gestiamo il tempo di attesa per la scrittura per 
evitare di attivare la scrittura di un altro byte prima 
che sia finita la scrittura dell’altro. 

jrs 1,eecr,$ 

A questo punto il dato è stato definitivamente scrit¬ 
to nella Eeprom Page 1 ed anche se si verificasse 
una caduta di tensione non andrebbe perso. 

Ora decrementiamo il registro w di uno: 

dee w 

Quando arriva a zero abbiamo completato il tra¬ 
sferimento e la contemporanea scrittura dei 14 
bytes, quindi saltiamo all’etichetta finwrp: 

jrz finwrp 

Se invece non è stato ancora completato, ci posi¬ 
zioniamo al byte successivo sia nella Eeprom Pa¬ 
ge 1 sia nella Data Ram: 

ine x 

ine y 


ed eseguiamo di nuovo il ciclo: 

jp eidos 

Una volta finita la fase di scrittura disattiviamo la 
modalità byte: 

Idi eecr,0 

Come avete avuto modo di capire con questo e- 
sempio, quando attiviamo la scrittura in modalità 
byte ogni variazione che apportiamo ai dati conte¬ 
nuti nella Eeprom Page selezionata viene imme¬ 
diatamente scritta nella memoria. Questo è il mo¬ 
tivo per cui dopo ogni fase di scrittura vi consiglia¬ 
mo sempre di disattivare la modalità scrittura. 

3° Esempio: Gestione del Tempo in Scrittura 

Prima di concludere vogliamo portarvi un ultimo 
semplice esempio per chiarire soprattutto l’aspetto 
della gestione del tempo di scrittura dentro le me¬ 
morie EEPROM. 

Nella fig.12 riportiamo le stesse istruzioni di fig.11 
con una piccola differenza. 

Abbiamo spostato l’istruzione jrs 1,eecr,$ dopo: 

eidos Idi wdog,0ffh 

e poi l’abbiamo ripetuta dopo l’etichetta: 

finwrp 

Qualcuno a questo punto si domanderà il perché 
visto che, come abbiamo spiegato, questa istru¬ 
zione serve per gestire il tempo di scrittura della 
EEPROM e sembrerebbe logico doverla inserire 
subito dopo l’istruzione di scrittura. 

Con questa istruzione si vuole solamente evitare 
che venga attivata un’altra fase di scrittura o la se¬ 
lezione di una pagina diversa di memoria prima che 
sia terminata la fase attuale di scrittura. 

Infatti quando si attiva la fase di scrittura nelle me¬ 
morie EEPROM il micro non sta ad aspettare che 
questa fase sia terminata, ma continua ad esegui¬ 
re le istruzioni successive. 

Se, per assurdo, le istruzioni successive fossero in 
numero tale che sommate ci danno un tempo su¬ 
periore ai 10-20 millisecondi stimati per la scrittu¬ 
ra in EEPROM, in teoria non sarebbe nemmeno 
necessario utilizzare l’istruzione: jrs 1,eecr,$. 

La condizione necessaria è che le istruzioni suc¬ 
cessive non contengano nessun altro comando i- 
nerente a queste memorie, perché non sarebbe e- 
seguito. Per non essere perciò costretti a contare 


i cicli delle istruzioni che seguono la scrittura nelle 
EEPROM si utilizza l’istruzione: 

jrs 1 ,eecr,$ 

Nella fig.12 abbiamo proposto un diverso modo di 
gestione della scrittura in EEPROM. 

Una soluzione questa che può velocizzare la ge¬ 
stione rispetto a quella di fig.11. 

Infatti dopo l’istruzione che “scrive” in EEPROM: 

Id (y),a 

il programma esegue le istruzioni successive, cioè: 


dee 

w 

jrz 

finwrp 

ine 

X 

ine 

y 

jP 

eidos 

eidos Idi 

wdog,0ffh 

e solo a questo 

punto eseguendo l’istruzione: 

jrs 

1 ,eecr,$ 


si ferma in attesa che la scrittura nella EEPROM 
sia terminata. 

E’ evidente che questa attesa sarà sicuramente mi¬ 
nore perché parte del tempo è già trascorso con 
l’esecuzione delle istruzioni precedenti. 

Nota: poiché scopo di questi esempi era chiarire 
come utilizzare le due modalità di scrittura nella 
memoria EEprom, per non complicare ulterior¬ 
mente la spiegazione, abbiamo utilizzato le istru¬ 
zioni JRZ e JRNZ in maniera impropria, senza te¬ 
nere conto cioè del fatto che hanno un salto con¬ 
dizionato a - 15/+16 bytes. 

Per l’uso corretto di queste istruzioni rimandiamo a 
quanto scritto nella rivista N.185. 




















software SIMULATORE 


Dopo il successo ottenuto con la prima versione del software simula¬ 
tore per micro ST6 (vedi rivista N.190), oggi vi presentiamo la nuova ver¬ 
sione che permette di simulare anche i micro della serie ST6260-ST6265. 
Con questo software simulatore potrete leggere e scrivere nelle memo¬ 
rie EEprom e Ram aggiuntiva, verificare la trasmissione Seriale sulla 
porta Spi, testare il PWM e l’Auto Reload Timer. 


A distanza di poco meno di un anno dalla pubbli¬ 
cazione del software simulatore per micro ST6, il 
nostro collaboratore, il Sig. Ivano Cesarin di Por- 
petto (UD), ha realizzato una nuova versione di si¬ 
mulatore in grado di testare tutti i micro della serie 
ST6210-15-20-25 compresi gli ST6260-65. 

Tutti i softwaristi che per motivi di lavoro o per 
hobby impiegano questi micro nei loro progetti, riu¬ 
sciranno con questo simulatore a scoprire più fa¬ 
cilmente eventuali errori e a correggerli. 

Tanto per cominciare vi diciamo che nel nuovo si¬ 
mulatore sono state eliminate tutte quelle piccole 
anomalie presenti in fase di apertura dei files con¬ 
tenenti i programmi da simulare. 

Rispetto alla versione precedente sono state ap¬ 
portate migliorie e aggiunte altre possibilità di si¬ 
mulazione che troverete molto interessanti, perché 
vi aiuteranno nei vostri test. 

Ad esempio, è stato aggiunto un valido e utile Help 
contestuale con semplici spiegazioni in italiano che 
vi accompagnano in ogni fase della simulazione. 


Come già abbiamo accennato, la novità principale 
della nuova versione riguarda la possibilità di si¬ 
mulare non solo i programmi scritti per i micro del¬ 
la serie ST6210 ecc., ma anche i programmi per la 
serie ST6260-65. 

Ciò significa che ora potete simulare le fasi di let¬ 
tura e scrittura nelle memorie Eeprom e Ram ag¬ 
giuntiva (definita dall’Autore Extra Ram), verifica- 
re la trasmissione seriale sulla porta Spi, testare il 

PWM e l’Auto Reload Timer. 

Per le modalità di installazione del programma e 
per l’uso dei comandi identici alla precedente ver¬ 
sione, rimandiamo a quanto già scritto nella rivista 
N.190. A questo proposito vi informiamo che se 
cambierete la directory di installazione del simu¬ 
latore, dovrete modificarla anche nel programma di 
esempio pedali.prg utilizzando un normale editor. 

Ora vi spieghiamo solo le nuove funzioni presenti 
in questo simulatore, completandole con le imma¬ 
gini delle finestre che appaiono sul monitor, perché 
una figura a volte chiarisce più di tante parole. 









































































LA VIDEATA PRINCIPALE 


ST6 


Dopo aver memorizzata nell’hard-disk la nuova ver¬ 
sione del programma simulatore, quando lanciate 
il programma appare la finestra di fig.1. 

1 - Cliccando su SimST622 lanciate la simulazio¬ 
ne dei programmi scritti per i soli microprocessori 
della serie ST6210-15-20-25. 

2 - Cliccando su SimST626 lanciate la simulazio¬ 
ne dei programmi scritti per i soli microprocessori 
della serie ST6260-65. 

3 - Cliccando su Conv > CMD potete effettuare la 
conversione di files .DAT in files .CMD. 

4 - Cliccando su Aiuto visualizzate le note di aiu¬ 
to del programma (Help contestuale). 


per micro ST6 


MODIFICA della EEPROM ed EXTRA RAM 

Dopo aver lanciato la simulazione di un program¬ 
ma per ST6260-65, scegliendo dal menu File (ve¬ 
di fig.2) il comando Modifica EEProm/Extra RAM 
potete accedere alla finestra di dialogo visibile in 
fig.3, in cui è possibile modificare tutta o una par¬ 
te sola della memoria Ram aggiuntiva (di seguito 
chiamata Extra Ram) o della memoria EEprom. 

A questa finestra si accede anche in fase di Crea¬ 
zione o Modifica Progetto cliccando sul pulsante 
Precarica EEprom (vedi fig.4). 

Una volta entrati nella finestra visibile in fig.3 è pos¬ 
sibile: 


m 





9 

SimST622 

SimST626 

Conv -> CMD 

Aiuto 


Uscita 


Fig.1 La videata principale della nuova ver¬ 
sione del software simulatore per i pro¬ 
grammi scritti per i micro ST6. 


y Debug Esegui Porte Finestre Variabili ? 

Nuovo Progetto CTRL+N 

Apri Progetto CTFìL+À 

Modifica Progetto CTRL+P 

a i* 


Salva Codice ASM 

sintonico 

i wdn,FFl 

8Dh,a 

i 8Fh,051 

i x,00h 

i y,85h 

i drfcuTjO: 

■= 1 i=i=i-1- ' 

Scrivi File dati in Ingresso CTRL+I 

Scrivi File Dati Uscita CTRL+0 

Option Byte 

Modifica E E Prom/Entra RAM 



Fig.2 Per modificare la memoria Eeprom o 
la Ram aggiuntiva, scegliete dal menu File 
il comando Modifica EEprom/Extra RAM. 



Fig.3 Dopo aver selezionato la memoria, per 
modificarne l’intero contenuto cliccate sul 
pulsante Riempimento. 


1 - Selezionare il tipo di memoria che si vuole mo¬ 
dificare o anche solo visualizzare, cliccando nel 
cerchietto alla destra delle scritte EEprom o Extra 
Ram. La scelta di una memoria esclude l’altra. 


Progetto C:\ST6\ESEMPI\TESTER.prg 


Micro 


SI 


Micro |ST6215 V] Frequenza 11.0000 MHz _-j 


2 - Modificare il contenuto di una singola cella cuc¬ 
candoci sopra 2 volte. In questo caso appare la ma¬ 
schera di fig.5 in cui bisogna digitare il valore che 
si vuole inserire in quella determinata cella. 

3 - Modificare tutto il contenuto della memoria se¬ 
lezionata cliccando sul pulsante Riempimento. Ap¬ 
pare sempre la maschera di fig.5, ma in questo ca¬ 
so il valore che digitate viene memorizzato in tut¬ 
te le celle della memoria. 



Precarica EEPROM 


0K 


Uscita 


Fig.4 Alla maschera di fig.3 si accede an¬ 
che in fase di Creazione - Modifica Proget¬ 
to, cliccando su Precarica EEPROM. 



































































































MODIFICA delle ISTRUZIONI 



Fig.5 Se avete cliccato sul pulsante riempi¬ 
mento, il valore che digitate verrà memo¬ 
rizzato in tutte le celle. 



Fig.6 Con il comando Edit Codice ASM dal 
menu Debug si può modificare l’istruzione 
senza interrompere la simulazione. 


||> NMI Flags C=0 


Et 


Scegli il Tipo di Editazione 
Modifica ; inserisci jl 


1BC1 

Qinfì 


0,port_b 
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Fig.7 L’istruzione può essere modificata o 
eliminata totalmente, inoltre è possibile in¬ 
serire una nuova istruzione. 
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009D ODI 
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Edit ASM 


Etichetta 


moria 


icti _ aarc,uun 


Idi orc,00h 

Modifica Istruzione 


xj 


Confermare ogni campo con Invio 
Istruz. 1* Campo 2* Campo 

|ldi |orc |00h 


3* Campo 


QK 


Uscita 


Fig.8 Con il pulsante Modifica, l’istruzione 
è visualizzata suddivisa in più campi corri¬ 
spondenti alle parti che la compongono. 



Fig.9 Se l’istruzione modificata è più lunga 
o più corta di quella originale, potete rim¬ 
piazzare i bytes mancanti con dei NOP. 


Grazie alla nuova versione è ora possibile cam¬ 
biare in tempo reale l’istruzione del programma 
che si sta simulando senza dover uscire dalla si¬ 
mulazione e senza dover ricompilare il sorgente. 

In questo modo si evitano grosse perdite di tempo 
e non si deve più impazzire per ritornare nel pun¬ 
to esatto in cui si era dovuta interrompere la simu¬ 
lazione per uscire dal programma, apportare la mo¬ 
difica e ricompilare il sorgente. 

Vediamo quindi quali passi bisogna compiere per 
correggere le istruzioni. 

Dal menu Debug cliccate su Edit Codice ASM (ve¬ 
di fig.6) per aprire la finestra di dialogo visibile in 
fig.7, nella quale è possibile scegliere fra tre diversi 
tipi di digitazione del programma che si testa: Mo¬ 
difica, Inserisci o Elimina. 

Fate attenzione perché le variazioni che apportate 
al sorgente con questi comandi durante la simula¬ 
zione non vengono memorizzate nel file .ASM, ma 
sono temporanee e verranno perse nel caso si 
chiuda la simulazione e se ne inizi una nuova. 
Potrete comunque memorizzarle in un file .TXT. 
In seguito vi spiegheremo come questa operazio¬ 
ne vi fornirà un’utile traccia per poter in seguito mo¬ 
dificare in maniera definitiva il file .ASM originale. 

Cliccando sul pulsante Modifica (vedi fig.7) com¬ 
pare la maschera di fig.8 in cui viene mostrata l’i¬ 
struzione che stava per essere eseguita suddivisa 

in Etichetta - Istruz. -1°-2°-3°Campo. 

Nel caso si sostituisca l’istruzione con un’istruzione 
più lunga o più corta, prima della conferma delle va¬ 
riazioni il programma vi chiede se volete inserire del¬ 
le istruzioni Nop per “riempire” i bytes restanti. 

Nota: ogni istruzione ha una sua precisa lunghez¬ 
za in bytes e a questo proposito consigliamo di 
consultare le tabelle pubblicate sulla rivista N.185. 

Nell’esempio visibile in fig.8 abbiamo sostituito l’i¬ 
struzione Idi orc,00h, lunga 3 bytes, con l’istru¬ 
zione reti lunga 1 bytes (vedi fig.9). 

Pertanto quando diamo l’OK, il programma ci chie¬ 
de se vogliamo che i bytes restanti, che, mancan¬ 
do l’Opcode, contengono dati non validi, vengano 
rimpiazzati con dei Nop. 

Inserendo due Nop non viene falsata la numera¬ 
zione del Displacement e l’istruzione seguente ini¬ 
zia dall’indirizzo di memoria esatto. 


















































































Se osservate infatti la fig.10 potete vedere che l’i¬ 
struzione Idi da 3 bytes è stata sostituita con tre 
istruzioni da 1 byte ciascuna: 

009A — reti 

009B 04 nop 

009C 04 nop 

Cliccando sul pulsante Inserisci di fig.7, compare 
la maschera di fig.11 in cui potete scrivere una nuo¬ 
va istruzione che automaticamente il programma 
inserirà prima dell’istruzione che stava per essere 
simulata. Naturalmente in questo caso bisogna fa¬ 
re molta attenzione, perché inserendo una nuova 
istruzione il Displacement viene variato e gli indi¬ 
rizzi di salto potrebbero essere tutti falsati. 

Cliccando sul pulsante Elimina, sempre in fig.7, 
compare la maschera di fig.12, in cui si chiede con¬ 
ferma della cancellazione della istruzione. 

Se si clicca su Sì, compare di seguito la masche¬ 
ra visibile in fig.13 che consente di rimpiazzare i 
bytes dell’istruzione eliminata con altrettanti Nop 
per non perdere il corretto Displacement. 

Come abbiamo accennato all’inizio del paragrafo, 
apportata la modifica potete salvarla in un file .TXT 
così da avere una traccia che vi servirà per cam¬ 
biare in maniera definitiva anche il file .ASM. 

Per fare questo, scegliete il comando Salva Codi¬ 
ce ASM dal menu File (vedi fig.14) e quando ap¬ 
pare la finestra di dialogo visibile in fig.15 date un 
nome al vostro file, quindi cliccate su OK. 

INSERIRE un’ONDA QUADRA CICLICA 

In questo paragrafo vi spieghiamo come procede¬ 
re per generare una forma di onda quadra sui pie¬ 
dini del microprocessore indicando solamente il 
periodo espresso in numero cicli e come visua¬ 
lizzare i segnali in ingresso e in uscita sui piedi¬ 
ni del micro anche in modalità numerica. 

Dopo aver lanciato la simulazione, cliccate sul pul¬ 
sante Cronologia Porte per far apparire la ma¬ 
schera di fig.16 in cui potete scegliere tra due mo¬ 
dalità di visualizzazione: Grafica e Numerica. 

Cliccando sul pulsante Grafica appare la masche¬ 
ra visibile in fig.17. 

Per il nostro esempio abbiamo selezionato la Por¬ 
ta C e le funzioni Edit e Limitato cliccando nelle 
apposite caselle. A sinistra sono evidenziati i pie¬ 
dini PC2 - PC3 e PC4 di porta C. 

Dopo aver selezionato uno dei piedini con il cur¬ 
sore, dovete scegliere il tipo di segnale in ingres¬ 
so (la lettera C sta per ciclico) e di seguito dove¬ 
te digitare il valore del periodo del ciclo. 


Jt Assembler 



Fig.10 Nell’esempio raffigurato, l’istruzione 
LDI, lunga tre bytes, è stata sostituita con 
l’istruzione RETI più due istruzioni NOP. 
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Inserisci Istruzione 


Confermare ogni campo con Invio 
Istruz. 1* Campo 2* Campo 3* Campo 


i—r 


0K 


Uscita 


Fig.11 Inserendo un’istruzione fate atten¬ 
zione, perché il Displacement viene variato 
e gli indirizzi di salto vengono falsati. 


01D2 FBFF 


01D4 BBFF 
01D 6 6BFF 
01D8 2BFF 
01DÀ 9FC1 
01DC 0D9001 


;moria 


loo loi 102 |Q3 

Fig.12 II comando di eliminazione di un’i¬ 
struzione dal programma in simulazione va 
sempre confermato. 
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Fig.13 Per non perdere il corretto Displace¬ 
ment, il simulatore vi chiede se deve rim¬ 
piazzare l’istruzione con altrettanti NOP. 
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Fig.14 Le variazioni apportate al sorgente 
durante la simulazione sono temporanee, 
quindi vanno salvate in un file .TXT. 






























































Fig.15 Con il comando Salva Codice ASM 
dal menu File, si apre questa finestra di dia¬ 
logo in cui dovete dare un nome al file .TXT 
che conterrà le variazioni fatte. 
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Modalità 1 di Visualizzazione 


Grafica 


Numerica 


Fig.16 Con questo simulatore è possibile 
generare una forma d’onda quadra sui pie¬ 
dini del microprocessore e vederla a video 
in modalità grafica. 



Fig.17 Nell’esempio riportato in questa fi¬ 
gura abbiamo immaginato di generare on¬ 
de quadre sui piedini di PORT C, quindi ab¬ 
biamo selezionato: Edit, Limitato e PC. 
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Fig.19 Per generare un’onda quadra con un 
periodo di 10 cicli è sufficiente digitare il 
valore 10 e cliccare su OK nella finestra di 
dialogo qui raffigurata. 



Fig.20 Dopo le operazioni visualizzate nel¬ 
le due figure precedenti, sul piedino PC2 è 
ora presente una forma d’onda quadra con 
un periodo di 10 cicli. 



Fig.21 Per generare un altro segnale ad on¬ 
da quadra cucchiamo sul piedino PC3 e per 
il tipo di segnale in ingresso scegliamo an¬ 
cora C, cioè segnale ciclico. 



Fig.18 Cuccando su PC2 si attiva la ma¬ 
schera per selezionare il tipo di segnale in 
ingresso. Per selezionare un segnale cicli¬ 
co utilizzate il pulsante con la lettera C. 


Fig.22 Per generare un’onda quadra con un 
periodo di 1 ciclo digitiamo 1 in questa fi¬ 
nestra di dialogo e cucchiamo su OK. La 
rappresentazione grafica appare in fig.23. 


















































































Fig.23 In questa figura potete vedere la rap¬ 
presentazione grafica dei segnali ad onda 
quadra con differenti periodi generati sui 
piedini PC2 e PC3 di port C. 



Fig.24 In questa figura potete vedere un e- 
sempio di visualizzazione numerica dei se¬ 
gnali immessi o rilevati sui piedini del mi- 
cro durante la simulazione. 
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Fig.25 Cliccando sul menu Variabili potete 
visualizzare il contenuto delle variabili uti¬ 
lizzate dal programma che si sta simulan¬ 
do in codifica esadecimale o binaria. 
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Fig.26 Per passare dalla codifica esadeci¬ 
male a quella binaria cliccate sulla lettera 
visibile in alto a destra: H per esadecimale 
e B per binario (vedi fig.25). 



Fig.27 Esempio di uno dei numerosi con¬ 
trolli inseriti dall’Autore per annotare gli er¬ 
rori. In questo caso il registro TSCR è sta¬ 
to caricato con un dato non valido. 



Fig.28 II simulatore ha rilevato un’altra i- 
struzione formalmente corretta, ma logica¬ 
mente errata: non è possibile scrivere nel¬ 
la EEprom se il bit 2 è uguale a zero. 



Fig.29 Cliccando sul pulsante Conv>CMD 
nella videata principale si attiva la Conver¬ 
sione dei segnali in uscita, memorizzati in 
un file .DAT, in segnali in ingresso, da me¬ 
morizzare in un file .CMD. In questo modo, 
partendo da un solo file, si possono gene¬ 
rare numerosi files di segnali in ingresso 
per le successive simulazioni. 




















































































Fig.30 Per aprire un file .DAT, che contiene 
i segnali in uscita ottenuti durante una si¬ 
mulazione, cliccate sul menu File e sce¬ 
gliete Apri File. 



Fig.31 Nella finestra di dialogo visibile in 
questa figura è necessario selezionare il 
nome del file di cui vogliamo convertire i 
segnali. Nel nostro caso è il file eet60.dat. 



Fig.32 Viene così generata questa masche¬ 
ra in cui a sinistra ci sono i piedini con i se¬ 
gnali da convertire e al centro l’elenco com¬ 
pleto dei piedini del micro. 


X*. Conversione DAT -> CMD 


File ? 


3 


EETG0.DAT 



DAT -> CMD 


Fig.33 Per effettuare la conversione clicca¬ 
te prima a sinistra e poi indicate nella co¬ 
lonna centrale su quale piedino deve esse¬ 
re trasferito il segnale. 



Fig.34 Completato il trasferimento dei se¬ 
gnali in uscita in segnali in ingresso, sce¬ 
gliete Salva File CMD dal menu File per me¬ 
morizzare la conversione. 



Fig.35 Nella finestra di dialogo visibile in 
questa figura è necessario scrivere il nome 
del file che contiene la conversione. Nel no¬ 
stro caso è il file eet60.cmd. 


























































































































































Le operazioni per generare una forma d’onda qua¬ 
dra con un periodo di 10 cicli sul piedino PC2 so¬ 
no visibili in sequenza nelle figg.18-20. 

Le figg.21-22 illustrano invece le operazioni ese¬ 
guite per generare una forma d’onda quadra con 
un periodo di 1 ciclo sul piedino PC3. 

Infine in fig.23 potete vedere il risultato delle due 
operazioni in forma grafica. 

Per visualizzare i segnali in modalità Numerica 
cliccate sull’apposito pulsante visibile nella ma¬ 
schera di fig.16. Si apre così la maschera di fig.24, 
in cui è riportato l’esempio di una serie di segnali, 
rappresentati per l’appunto in forma numerica, ri¬ 
levati dopo la simulazione di un programma. 

Per la spiegazione dei singoli simboli e numeri che 
appaiono in questa figura, rimandiamo alla consul¬ 
tazione dell’Help contestuale fornito con questo 
software simulatore. 

VISUALIZZARE le VARIABILI 

Il contenuto delle variabili utilizzate nel program¬ 
ma che si sta simulando può essere visualizzato 
sia in codifica esadecimale sia in codifica binaria. 

Cliccando sul menu Variabili si apre una finestra 
di dialogo che mostra, come nell’esempio di fig.25, 
l’elenco di variabili inserite nella lista di visualizza¬ 
zione durante la simulazione del programma. 
Come noterete subito il valore che contengono è 
espresso in Esadecimale sotto la colonna HEX e 
in Decimale sotto la colonna Dee. 

Se a questo punto cliccate sopra il pulsante con¬ 
trassegnato dalla lettera B, in alto a destra, lo stes¬ 
so elenco viene visualizzato con il valore espresso 
in Binario (vedi fig.26). 

Per tornare alla situazione di fig.25 bisogna clicca¬ 
re sul pulsante contrassegnato dalla lettera H. 

RILEVAMENTO degli ERRORI 

Per facilitare il rilevamento di errori durante la si¬ 
mulazione sono stati aggiunti numerosi controlli 
sulla validità delle istruzioni che vengono via via 
eseguite e sono state previste segnalazioni ap¬ 
posite che informano il programmatore delle ano¬ 
malie riscontrate. 

A titolo di esempio, nelle figg.27-28 abbiamo ripor¬ 
tato solo due delle molteplici indicazioni di anoma¬ 
lie previste dal simulatore, che, nel caso specifico, 
il Compilatore Assembler non avrebbe potuto se¬ 
gnalare dal momento che, pur errate logicamente, 
le istruzioni sono formalmente corrette. 
Cliccando su OK è possibile continuare nella si¬ 
mulazione e verificare così fino in fondo l’esattez¬ 
za del programma. 


SEGNALI in USCITA e in INGRESSO 

Da ultimo, è stata aggiunta la possibilità di con¬ 
vertire i segnali in uscita, ottenuti durante una si¬ 
mulazione e memorizzati in un file .DAT, in segnali 
in ingresso, memorizzandoli in un file .CMD da u- 
tilizzare in una successiva simulazione. 

E’ inoltre possibile redirezionare i segnali da un pie¬ 
dino ad un altro sia nei files .DAT sia nei .CMD. 
Questa possibilità di conversione è molto utile per¬ 
ché permette, partendo da un unico file contenen¬ 
te dei segnali, di generare numerosi files di se¬ 
gnali in ingresso che potranno così essere utilizzati 
in numerose simulazioni. 

Cliccando su Conv > CMD nella videata principa¬ 
le (vedi fig.1) si attiva la funzione di Conversione 
ed appare la maschera visibile in fig.29. 

Per selezionare il file da “convertire”, cliccate su 
Apri File dal menu File di fig.30. 

Nel nostro esempio abbiamo selezionato il file 
eet60.dat (vedi fig.31) generato da una preceden¬ 
te simulazione. 

Cliccando su OK appare la maschera di fig.32, ge¬ 
nerata dalla selezione del file. 

Sulla sinistra sono riportate tante caselle all’inter¬ 
no delle quali sono elencate le sigle dei piedini che 
contengono i segnali da convertire. 

Al centro è visibile una barra di scorrimento con l’e¬ 
lenco completo di tutti i piedini del micro, mentre 
sulla destra vedete tante caselle vuote. 

Cliccando rispettivamente nella casella di sinistra 
per selezionare il piedino e poi nella barra di cen¬ 
tro per indicare su quale piedino devono essere 
“trasferiti” i segnali, si effettua la conversione. 

Se osservate la fig.33 vedrete che, per quanto ri¬ 
guarda i primi tre piedini, abbiamo trasferito i se¬ 
gnali da .DAT a .CMD sugli stessi piedini, mentre 
per quanto concerne il quarto piedino, cioè PB7 (e- 
videnziato in giallo dal programma stesso), abbia¬ 
mo trasferito i suoi segnali sul piedino PCO. 
Completato il trasferimento dei segnali, è suffi¬ 
ciente scegliere il comando Salva File CMD dal 
menu File (vedi fig.34) per memorizzare la con¬ 
versione in un file che, sempre nel nostro esempio, 
abbiamo chiamato eet60.cmd (vedi fig.35). 


COSTO del PROGRAMMA 

Questo nuovo ed aggiornato software simulato¬ 
re, che sostituisce la precedente versione pubbli¬ 
cata sulla rivista N.190, è inserito nei 2 dischetti 
floppy siglati ST626/1 - ST626/2. 

Costo dei due dischetti con IVA inclusa .€ 10,32 




LA funzione SPI 


Tutti i micro ST6260-65 possiedono una Serial-Synchronous Peripheral 
Interface conosciuta più comunemente come SPI, che può essere uti¬ 
lizzata per lo scambio dati tra due micro o per dialogare con una EE- 
prom ecc. In questo articolo vi spieghiamo come settare correttamente 
i piedini e i registri coinvolti nella trasmissione e ricezione dei dati. 


La SPI o Serial Peripheral Interface 

La SPI è uno standard di trasmissione e ricezione 
dati in modalità seriale sincrona che può essere u- 
tilizzato, con opportune istruzioni di programma, per 
dialogare con una Eeprom esterna, con uno Shift re- 
gister, con un Micro, per pilotare dei display ecc. 
Uno dei vantaggi che offre la SPI riguarda il fatto 
che essendo la trasmissione e la ricezione dei da¬ 
ti completamente automatica, il microprocessore 
può continuare ad eseguire altre istruzioni. 

È inoltre possibile effettuare una ricezione di dati 
da un integrato e ritrasmetterli ad un terzo presso¬ 
ché simultaneamente, senza mai uscire cioè dalla 
stessa routine. 

Ovviamente questa funzione viene attivata tramite 
il settaggio di particolari registri; in caso contrario i 
piedini coinvolti continueranno a svolgere i norma¬ 
li compiti per cui sono stati programmati. 


È quindi importante conoscere bene le specifiche 
della funzione SPI, che può avere ben 6 differenti 

configurazioni o modalità. 

- One wire Autoclocked Mode: viene utilizzato un 
solo piedino per l’invio dei dati ed il clock di tra¬ 
smissione è prestabilito. 

- Two wire Half Duplex Mode: vengono coinvolti 
2 piedini: uno definisce il clock di trasmissione, l’al¬ 
tro, alternativamente, serve per la trasmissione e 
per la ricezione. 

- Tree wire Half Duplex with Master/Slave se- 
lect: è la modalità utilizzata dagli ST6260/65 e vi 
sarà spiegata nel corso di questo articolo. Per il 
momento ci limitiamo a dire che in questa moda¬ 
lità vengono utilizzati 3 piedini indicati con le sigle 
Sin (ingresso), Sout (uscita) e Sck (clock). 








































































- Tree wire Full Duplex Mode: sono coinvolti 3 
piedini ed è possibile la contemporanea trasmis¬ 
sione e ricezione dei dati. 

- Tree wire Full Duplex Mode with Clock Arbi- 
tration: è il risultato della fusione delle modalità 2 
e 4 e implica l’uso di 3 piedini. 

- Four wire Full Duplex Mode with Master/Sla¬ 
ve select: ha origine dalla fusione delle modalità 3 
e 4 ed impiega 4 piedini. 


L’interfaccia SPI negli ST6260 - ST6265 

I microprocessori della serie ST6260 - ST6265 u- 
tilizzano solo la configurazione: 


Tree wire Half Duplex with Master/Slave select 


Questa configurazione impiega tre piedini di Por¬ 
ta C: uno per la ricezione (Sin), uno per la tra¬ 
smissione (Sout) ed uno per inviare o ricevere il 
segnale di clock (Sck) per il sincronismo dei dati. 

Nel caso specifico dei micro ST6260 ed ST6265 i 
dati da trasmettere o da ricevere si trovano memo¬ 
rizzati in un apposito shift register da 1 byte. 

Ciò porterebbe a concludere che sia possibile tra¬ 
smettere o ricevere un massimo di 8 bits per ciclo, 
ma vedremo in seguito che non è proprio così. 

Se si devono trasmettere più dati occorre scrivere 
una subroutine che esegua tanti cicli di trasmis¬ 
sione quanti sono i bytes da inviare; ad esempio, 
se volessimo trasmettere 32 bytes, la subroutine 
dovrebbe eseguire 32 cicli di trasmissione. 

I termini Master Mode indicano che i dati vengo¬ 
no inviati dal micro ad un integrato esterno, uti- 


per lo scambio DATI 


TEST/Vpp 



Vdd Vss OSCin OSCout RESET 


Fig.1 Schema a blocchi dei mi¬ 
cro ST6260-65.1 micro di que¬ 
sta serie possiedono al loro 
interno una comoda e pratica 
Serial-Synchronous Periphe- 
ral Interface, comunemente 
chiamata SPI, che consente lo 
scambio di dati tra due o più 
micro o tra un micro e altri in¬ 
tegrati. La configurazione u- 
sata dagli ST6 permette di at¬ 
tivare una comunicazione Half 
Duplex su tre fili con selezio¬ 
ne dispositivo Master e Slave. 






























































































lizzando il clock generato dallo stesso micro. 

I termini Slave Mode indicano che i dati vengono 
inviati da un integrato esterno al micro, utilizzan¬ 
do il clock generato dall’integrato esterno. 

Cercate di ricordare la differenza tra Master e Sla¬ 
ve, perché nell’articolo citeremo frequentemente 
queste due modalità di trasmissione. 

Vi sono altre parole che troverete spesso nella do¬ 
cumentazione relativa ai microcontrollori e, tra que¬ 
ste, vale la pena spiegare subito i termini Rising 
edge e Falling edge. 

Rising edge indica il fronte di salita dell’onda qua¬ 
dra del clock di trasmissione. 

Falling edge indica il fronte di discesa dell’onda 
quadra del clock di trasmissione. 

Tenete presente che per utilizzare al meglio lo stan¬ 
dard SPI sarebbe preferibile che tutti gli integrati o 
i micro con i quali desiderate dialogare dispones¬ 
sero di tale funzione. 

In teoria si può dialogare anche con integrati o mi¬ 
cro sprovvisti della funzione SPI; in questi casi però 
potrebbe essere necessario utilizzare un piedino in 
più per attivare un eventuale segnale di conferma 
trasmissione o ricezione o per memorizzare i dati 
trasmessi (latch, strobe, ecc.). 

Inoltre potrebbe essere necessario realizzare un 
certo numero di subroutines, perdendo così il van¬ 
taggio dell’esecuzione automatica della SPI. 


ìpdv = Spi Divide Register E il registro che ge¬ 


stisce la velocità di trasmissione e il numero di bit 
da inviare e ricevere. E’ lungo 1 byte ed è definito 
all’indirizzo 0E1H. I suoi 8 bits da 7 a 0 verranno 
sempre indicati con le seguenti sigle. 
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>pda = Spi Data Register. E il registro nel quale 


vengono memorizzati i dati ricevuti o da trasmet¬ 
tere. Si tratta di uno shift register quindi la rice¬ 
zione-trasmissione dei dati viene effettuata shif- 
tando di un bit verso sinistra ad ogni fronte del 
clock. E’ lungo 1 byte ed è definito aH’indirizzo 
OEOH. I suoi 8 bits da 7 a 0 verranno sempre in¬ 
dicati con le seguenti sigle. 
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mise = Miscellaneous Register. Solitamente que¬ 
sto registro, lungo 1 byte e definito aH’indirizzo 
ODDH, contiene dati per settare diverse funzioni. 
Nel nostro caso viene utilizzato solo il bit 0. 


7 

6 

5 

4 

3 

2 

1 

0 








MO 


CONFIGURAZIONE dei PIEDINI 


PIEDINI e REGISTRI della SPI 


Per attivare la funzione SPI sui piedini PC2-PC3- 
PC4 di Port_C dei micro ST6260-ST6265 occorre 
settare 4 registri, diversamente questi tre piedini 
svolgeranno le normali funzioni di 1-0. 

Prima però di fornire le necessarie spiegazioni per 
la loro configurazione, dovete prendere confidenza 
con i termini e le abbreviazioni utilizzate. 


Sin = Serial Input. È il piedino PC2 di Port_C u- 
tilizzato per la ricezione dati. 

Sout = Serial Output. È il piedino PC3 di Port_C 
utilizzato per la trasmissione dati. 

Sck = Serial Clock. È il piedino PC4 di Port_C u- 
tilizzato per il segnale di clock di trasmissione o ri¬ 
cezione dati. 


Ora cercheremo di spiegarvi nel modo più sempli¬ 
ce possibile la configurazione iniziando da alcune 
note generali riguardanti i tre piedini di Port_C. 
Innanzitutto va ricordato che i piedini PC2 Sin e 
PC4 Sck vengono utilizzati come normali piedini 
standard 1-0 quando il bit 4 del registro spmc si¬ 
glato Spclk è a 0. Lo stesso dicasi per il piedino 
PC3 Sout se il bit 0 MO del registro mise è a 0. 
Se tramite i registri standard per la gestione di 
port_c, pdir_c, popt_c (vedi rivista N.175/176), il 
piedino PC2 sin viene configurato in input, qual¬ 
siasi segnale che entra sul piedino PC2 (non im¬ 
porta se si è in Master Mode o in Slave Mode) vie¬ 
ne automaticamente memorizzato nello shift regi¬ 
ster spda, indipendentemente dallo stato logico del 
bit Spclk del registro spmc. 


È il registro che con¬ 
lungo 1 byte ed è de¬ 
finito all’indirizzo 0E2H. I suoi 8 bits da 7 a 0 ver¬ 
ranno sempre indicati con le seguenti sigle. 
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Se settiamo a 1 il bit MO del registro mise, il pie¬ 
dino PC3 Sout viene configurato come SPI push- 
pull output, indipendentemente dai settaggi pre¬ 
senti sui registri port_c, pdir_c e popt_c. 

Per trasmettere il clock (Master Mode), il piedino 
PC4 Sck deve essere settato come push-pull out¬ 
put nei registri port_c, pdir_c e popt_c, inoltre, va 
settato a 1 il bit Spclk del registro spmc. 


spmc = Spi Mode Register. 

traila tutta l’interfaccia SPI. È 

































































Per ricevere il clock (Slave Mode), il piedino PC4 
Sck deve essere settato come input nei registri 
port_c, pdir_c e popt_c, inoltre, deve essere set¬ 
tato a 0 il bit Spclk del registro spmc. 

Con quest’ultima configurazione il piedino PC4 può 
essere usato anche come piedino in input. 

SINCRONISMO SPI 

Nel paragrafo successivo chiariremo bit per bit il 
settaggio dei registri coinvolti nella gestione della 
SPI, ma prima di continuare è necessario illustra¬ 
re con l’aiuto di qualche disegno, cosa significano 
i termini rising edge, falling edge, polarità e fa¬ 
se, perché la combinazione di questi dati ci con¬ 
sente di dialogare con la quasi totalità degli inte¬ 
grati che dispongono della funzione SPI. 


Nelle figg.2-5 potete vedere i 4 tipi di diagramma 
di sincronismo SPI in cui è stata ipotizzata una tra¬ 
smissione-ricezione di 8 bits. 

In queste figure sono richiamati i piedini PC4-PC3 
di Port_C, che abbiamo indicato con le sigle Sck 
e Sout, ed il bit 7 Sprun del registro spmc. A pro¬ 
posito di questo bit è il caso di anticipare che Sprun 
sta per Spi run; in altre parole questo bit è lo start 
della funzione SPI. 

Quando Sprun viene posto a 1 inizia la trasmis¬ 
sione o la ricezione dei dati, completata la quale il 
bit va automaticamente a 0. 

Per semplificare il disegno non abbiamo riportato il 
piedino PC2 Sin; d’altra parte la logica descritta per 
la trasmissione è identica in caso di ricezione. 
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Fig.2 Diagramma di sincronismo SPI in cui è stata ipotizzata una trasmissione di 8 bits 
dal piedino Sout. Gli 8 cicli di trasmissione sono visibili sul piedino Sck, sul quale il se¬ 
gnale di clock dal livello logico 0 si porta al livello logico 1 e poi torna sul livello logico 
0 per 8 volte. Quando la forma d’onda quadra è 0-1-0 la POLARITÀ’ del clock è NORMA¬ 
LE e poiché la trasmissione inizia sul primo fronte di clock (fronte di salita), anche la FA¬ 
SE è NORMALE. Per avere una trasmissione con queste caratteristiche bisogna settare a 
0 sia il bit cpol sia il bit epha del registro spmc. 
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Fig.3 Diagramma di sincronismo SPI in cui è stata ipotizzata una trasmissione di 8 bits 
dal piedino Sout. Gli 8 cicli di trasmissione sono visibili sul piedino Sck, sul quale il se¬ 
gnale di clock dal livello logico 0 si porta al livello logico 1 e poi torna sul livello logico 
0 per 8 volte. Quando la forma d’onda quadra è 0-1-0 la POLARITÀ’ del clock è NORMA¬ 
LE e poiché la trasmissione inizia sul secondo fronte di clock (fronte di discesa), si ha u- 
no SLITTAMENTO di FASE. Per avere una trasmissione con queste caratteristiche biso¬ 
gna settare a 0 il bit cpol e settare a 1 il bit epha del registro spmc. 
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Fig.4 Diagramma di sincronismo SPI in cui è stata ipotizzata una trasmissione di 8 bits 
dal piedino Sout. Gli 8 cicli di trasmissione sono visibili sul piedino Sck, sul quale il se¬ 
gnale di clock dal livello logico 1 si porta al livello logico 0 e poi torna sul livello logico 
1 per 8 volte. Quando la forma d’onda quadra è 1-0-1 la POLARITÀ’ del clock è INVERTI¬ 
TA e poiché la trasmissione inizia sul primo fronte di clock (fronte di discesa), la FASE è 
NORMALE. Per avere una trasmissione con queste caratteristiche bisogna settare a 1 il 
bit cpol e settare a 0 il bit cpha del registro spmc. 



Fig.5 Diagramma di sincronismo SPI in cui è stata ipotizzata una trasmissione di 8 bits 
dal piedino Sout. Gli 8 cicli di trasmissione sono visibili sul piedino Sck, sul quale il se¬ 
gnale di clock dal livello logico 1 si porta al livello logico 0 e poi torna sul livello logico 
1 per 8 volte. Quando la forma d’onda quadra è 1-0-1 la POLARITÀ’ del clock è INVERTI¬ 
TA e poiché la trasmissione inizia sul secondo fronte di clock (fronte di salita), si ha uno 
SLITTAMENTO di FASE. Per avere una trasmissione con queste caratteristiche bisogna 
settare a 1 sia il bit cpol sia il bit cpha del registro spmc. 


Osservando le figg.2-5 si può innanzitutto notare 
che il bit Sprun passa dallo stato logico 0 allo sta¬ 
to logico 1 (inizio della trasmissione o ricezione) e 
mantiene questo stato per 8 cicli di trasmissione- 
ricezione dati. Gli 8 cicli di clock sono visibili co¬ 
me altrettante onde quadre sul piedino Sck. 

Nelle figg.2-3 il segnale di clock parte con un li¬ 
vello logico 0, si porta a 1, mantiene questo sta¬ 
to per un breve periodo dopodiché si riporta a 0. 

Quando si è in presenza di questa forma d’onda 
quadra (0 -1 - 0) si parla di polarità di clock nor¬ 
male. Ogni volta che il clock dal livello logico 0 si 
porta sul livello logico 1 si ha un fronte di salita 
ed ogni volta che dal livello logico 1 si porta sul 
livello logico 0 si ha un fronte di discesa. 


Quando la trasmissione e/o ricezione avviene sul 
1 ° fronte di clock (che in polarità normale è il fron¬ 
te di salita) si parla di fase normale, quando av¬ 
viene sul 2° fronte di clock (che in polarità norma¬ 
le è il fronte di discesa) si parla di shift di fase. 

Se siamo in trasmissione viene prelevato il livello lo¬ 
gico contenuto nel registro spda partendo dal bit 7 
ed inviato sul piedino Sout. Se siamo in ricezione 
viene letto il livello logico presente sul piedino Sin e 
memorizzato nel registro spda partendo dal bit 0. 
Dopo 8 cicli, quando il piedino Sck passa dal li¬ 
vello logico 1 al livello logico 0, automaticamen¬ 
te termina la trasmissione o ricezione dei dati. 

Nella fig.2 la trasmissione-ricezione dei dati avvie¬ 
ne in polarità normale e ha inizio sul 1 ° fronte di 
clock, quindi è in fase normale. 














































































Ora osserviamo la fig.3 dove, come abbiamo ap¬ 
pena detto, il segnale di clock sul piedino Sck par¬ 
te con un livello logico 0 e si porta a livello logi¬ 
co 1 (polarità normale), ma la trasmissione-rice¬ 
zione non inizia sul 1° fronte, bensì sul 2° fronte 
di clock, è cioè shiftata di fase. 

Se siamo in trasmissione viene prelevato il livello 
logico contenuto nel registro spda partendo dal bit 
7 e inviato sul piedino Sout. Se siamo in ricezione 
viene letto il livello logico presente sul piedino Sin 
e memorizzato nel registro spda partendo dal bit 0. 
Dopo 8 cicli, quando il piedino Sck passa dal li¬ 
vello logico 1 al livello logico 0, automaticamen¬ 
te termina la trasmissione o ricezione dei dati. 

Nella fig.3 la trasmissione-ricezione dati avviene in 

polarità normale, ma ha inizio sul 2° fronte di 
clock quindi è in slittamento di fase. 

Ora osserviamo le figg.4-5, in cui il segnale di clock 
sul piedino Sck parte dal livello logico 1, si porta 
a 0 e poi ritorna a 1. Quando si è in presenza di 
questa forma d’onda quadra (1 - 0 - 1) si parla di 
polarità di clock invertita. 

Ogni volta che il clock dal livello logico 1 si porta 
sul livello logico 0 si ha un fronte di discesa ed 
ogni volta che dal livello logico 0 si porta sul li¬ 
vello logico 1 si ha un fronte di salita. 

Quando la trasmissione e/o ricezione avviene sul 
1 “fronte di clock (che in polarità invertita è il fron¬ 
te di discesa) si parla di fase normale, quando av¬ 
viene sul 2° fronte di clock (che in polarità inver¬ 
tita è il fronte di salita) si parla di shift di fase. 

Se siamo in trasmissione viene prelevato il livello 
logico contenuto nel registro spda partendo dal bit 
7 e inviato sul piedino Sout. Se siamo in ricezione 
viene letto il livello logico presente sul piedino Sin 
e memorizzato nel registro spda partendo dal bit 0. 
Dopo 8 cicli, quando il piedino Sck passa dal li¬ 
vello logico 0 al livello logico 1 , automaticamen¬ 
te termina la trasmissione o ricezione dei dati. 

Nella fig.4 la trasmissione-ricezione dati avviene in 

polarità invertita e ha inizio sul 1 “fronte di clock, 
quindi è in fase normale. 

Per finire passiamo alla fig.5 dove il segnale di 
clock sul piedino Sck parte sempre con un livel¬ 
lo logico 1 e si porta a livello logico 0, ma la tra¬ 
smissione-ricezione non inizia sul 1 0 fronte, bensì 
sul 2° fronte di clock, è cioè shiftata di fase. 

Se siamo in trasmissione viene prelevato il livello 
logico contenuto nel registro spda partendo dal bit 
7 e inviato sul piedino Sout. Se siamo in ricezione 
viene letto il livello logico presente sul piedino Sin 
e memorizzato nel registro spda partendo dal bit 0. 


Dopo 8 cicli, quando il piedino Sck passa dal li¬ 
vello logico 0 al livello logico 1 , automaticamen¬ 
te termina la trasmissione o ricezione dei dati. 

Nella fig.5 la trasmissione-ricezione dati avviene in 

polarità invertita, ma ha inizio sul 2° fronte di 
clock, quindi è in slittamento di fase. 


CONFIGURAZIONE dei REGISTRI 


Il registro spmc (Spi Mode Register) è quello che 
in pratica controlla tutta la gestione SPI. 
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Sprun bit 7 = Spi run. Quando viene posto a li¬ 
vello logico 1 ha inizio la trasmissione dati (Ma¬ 
ster Mode) o la ricezione dati (Slave Mode). Alla 
fine della trasmissione o della ricezione questo bit 
si porta automaticamente a livello logico 0. 

Se viene forzato a livello logico 0 dal programma, 
si interrompe la trasmissione o la ricezione. 
Quando va a 0 può generare una richiesta di In- 
terrupt se il bit 6 (Spie) è settato a 1 ed è stata at¬ 
tivata la routine di Interrupt di SPI nel registro ior. 
Utilizzato assieme al bit 2 (Spstrt) stabilisce una 
condizione di start in ricezione o trasmissione. 

In questo caso la trasmissione-ricezione dati ha i- 
nizio solo se viene rilevato un segnale esterno con 
un fronte di salita (rising edge) sul piedino PC2. 


Spie bit 6 = Spi Enable Interrupt. Quando questo 
bit è settato a 1 abilita l’interrupt SPI; quando è re¬ 
settato, cioè posto a 0, lo disabilita. 


Cpha bit 5 = Clock Fase Selection. Quando è set¬ 
tato a 0 si ha una fase normale di clock (vedi figg.2 
e 4), quando è settato a 1 si ha lo slittamento di fa¬ 
se (vedi figg.3 e 5). 


Spclk bit 4 = Base Clock Selection. Questo bit 
selezione il clock. In pratica dice al microcontrol¬ 
lore se il clock sarà interno o esterno. 

Se è settato a 0 e nel contempo il PC4 Sck è con¬ 
figurato input, viene attivata la ricezione (Slave 
Mode) pertanto il clock viene prelevato esterna¬ 
mente dall’integrato che invia i dati. 

Se invece è settato ale contemporaneamente il 
PC4 Sck è stato configurato in output push-pull, 
viene attivata la trasmissione (Master Mode) per¬ 
tanto il clock risulta interno. 

In questo caso il clock viene ricavato dalla fre¬ 
quenza del quarzo diviso 13 ed ulteriormente divi¬ 
so per il valore contenuto in alcuni bits del registro 
spdv, come spiegheremo più avanti. 























Spiri bit 3 = Input Selection. Questo bit gestisce 
la selezione di input. Se è settato a 1 abilita il tra¬ 
sferimento dei dati ricevuti da PC2 Sin nello shift 
register spda e quindi al termine della ricezione 
questo registro conterrà i dati ricevuti. 

Se è settato a 0 il trasferimento viene disabilitato e 
i dati letti su PC2 Sin dovranno essere trattatati di¬ 
rettamente dalle istruzioni di programma. In questo 
caso PC2 Sin si comporta praticamente come un 
normale piedino. 


Spstrt bit 2 = Start Selection. Questo bit viene u- 
tilizzato per gestire la selezione di Start, possibilità 
questa che può risultare molto utile in determinati 
casi. Infatti, se questo bit è settato a 0, la fase di 
trasmissione o di ricezione SPI ha inizio quando 
viene posto a 1 il bit Sprun. 

Se invece viene posto ale contemporaneamen¬ 
te si setta a 1 anche il bit Sprun, la ricezione o la 
trasmissione ha inizio solamente quando viene ri¬ 
cevuto un fronte di salita esterno su PC2 Sin, cioè 
un segnale rising edge. 

In questo modo è possibile pilotare esternamente 
l’inizio di una trasmissione-ricezione SPI. Una vol¬ 
ta che è iniziata, la trasmissione-ricezione continua 
anche se il segnale su PC2 Sin viene resettato. 


Efilt bit 1 = Enable Filter. Questo bit serve per a- 
bilitare o disabilitare un filtro anti-rumore sui piedi¬ 
ni PC2 Sin e PC4 Sck. Se è settato a 0 il filtro è 
disabilitato, se è settato a 1 è abilitato. 

In fase di ricezione dati capita di frequente che sui 
piedini interessati si trovino disturbi di qualsiasi na¬ 
tura che potrebbero falsare i dati ricevuti. 

Quando è abilitato, questo filtro elimina ogni im¬ 
pulso rilevato che sia più piccolo di 1-2 periodi del 
clock principale del micro. 

In pratica ad ogni clock interno del micro viene let¬ 
to una prima volta il dato sul piedino, il clock suc¬ 
cessivo viene riletto e se il dato è lo stesso viene 
accettato. Se alla seconda lettura il dato risulta in¬ 
vece diverso, vengono ignorati entrambi perché 
considerati disturbi. 

Così, ad esempio, se il micro ST6265 lavora ad u- 
na frequenza di 8 MHz, avremo un filtraggio ogni 
125 nanosecondi ed un possibile ritardo sulla con¬ 
ferma di un segnale fino a 250 nanosecondi. 


Cpol bit 0 = Clock Polarity. Questo bit gestisce la 
polarità del clock sul piedino Sck. Se è settato a 
0 la polarità è normale (vedi figg.2-3), se è setta¬ 
to a 1 la polarità è invertita (vedi figg.4-5). 


lori in questo registro quando Sprun è settato a 1 , 
vale a dire quando è attiva la trasmissione o la ri¬ 
cezione dei dati. 
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Spint bit 7 = Input Flag. Questo bit è un read an 
clean only, ciò significa che lo possiamo solo re- 
settare a 0 o leggere. Infatti viene settato a 1 dal 
micro solo quando viene riscontrata la fine della ri¬ 
cezione o della trasmissione SPI ed è stata attiva¬ 
ta una richiesta di Interrupt, come abbiamo spie¬ 
gato nel registro spmc a proposito del bit 6. 
Questo bit deve poi essere azzerato dal program¬ 
ma una volta che è sia stata eseguita la sub-routi¬ 
ne attivata dall’lnterrupt sopracitato. 


Div6-Div3 bits 6-5-4-3 = Burstmode Bit Clock Pe- 
riod. Questi bits servono per configurare il nume¬ 
ro dei bits per ogni ciclo di SPI da ricevere o tra¬ 
smettere. Naturalmente, siccome la trasmissione- 
ricezione avviene sul fronte del clock, in pratica si 
configura così anche il numero dei clock per quel 
ciclo di trasmissione-ricezione. 

Nella Tabella N.1 è riportata la loro configurazio¬ 
ne. Per ogni ciclo è possibile trasmettere-ricevere 
un massimo di 8 bits in quanto il registro dal qua¬ 
le vengono trasmessi è lungo solo 1 byte. 

È però possibile configurare la tabella per una tra¬ 
smissione fino a 15 clock per ciclo, ma in questo 
caso sui fronti di clock eccedenti verranno inviati i 
livelli logici 0 subentrati ai valori presenti nel re¬ 
gistro spda per effetto dello shiftamento durante la 
trasmissione. 


Ad esempio, se configuriamo questi piedini per in¬ 
viare 11 clock per ciclo, con i primi 8 clock ver¬ 
ranno trasmessi i primi 8 bits così come si trovano 
nel registro spda (vedi fig.6), mentre per i succes¬ 
sivi 3 clock verranno trasmessi i livelli logici 0. 
Questo significa che se il contenuto del registro 
spda del micro che trasmette era: 



dopo 11 clock di trasmissione, il registro spda del 
micro che ha ricevuto i dati conterrà questi valori: 



Il registro spdv o Spi Divide Register è il registro 
che gestisce il numero dei bits da inviare-ricevere 
e che permette di configurare la frequenza di tra¬ 
smissione. Non è possibile scrivere o variare i va¬ 


perché, come abbiamo avuto già modo di ricorda¬ 
re e come spiegheremo più dettagliatamente in se¬ 
guito, i bits, man mano che vengono ricevuti, shif- 
tano verso sinistra nel registro spda. 















































Fig.6 Diagramma di sincronismo SPI in cui abbiamo ipotizzato una trasmissione di 11 
clock per ciclo. Con i primi 8 clock vengono trasmessi gli 8 bits contenuti nel registro 
spda, mentre per i successivi tre clock vengono trasmessi dei livelli logici 0. Poiché i da¬ 
ti, man mano che vengono ricevuti, shiftano nel registro spda del micro ricevente verso 
sinistra, dopo 11 clock il registro spda conterrà solo gli ultimi 8 bits trasmessi. La quan¬ 
tità dei bits da inviare deve essere identica alla quantità dei bits da ricevere, cioè i regi¬ 
stri spdv del Master e dello Slave devono avere la stessa configurazione. 


Nota: ovviamente il registro spdv deve avere la 
stessa configurazione sia in master sia in slave, 
cioè il numero dei bits da inviare e ricevere deve 
essere lo stesso. 


TABELLA N.1 


DV6 

DV5 

DV4 

DV3 

numero bits 

0 

0 

0 

0 

riservato 

0 

0 

0 

1 

1 

0 

0 

1 

0 

2 

0 

0 

1 

1 

3 

0 

1 

0 

0 

4 

0 

1 

0 

1 

5 

0 

1 

1 

0 

6 

0 

1 

1 

1 

7 

1 

0 

0 

0 

8 

1 

0 

0 

1 

9 

1 

0 

1 

0 

10 

1 

0 

1 

1 

11 

1 

1 

0 

0 

12 

1 

1 

0 

1 

13 

1 

1 

1 

1 

14 

1 

1 

1 

1 

15 


CD2-CD0 bits 2-1-0 = Clock Rate Selection. Que¬ 
sti bits servono per ottenere il numero da utilizza¬ 
re per configurare la frequenza di clock di trasmis¬ 
sione. In sostanza dalla configurazione appropria¬ 
ta di questi tre bits (vedi Tabella N.2) otteniamo il 
divisore. 


TABELLA N.2 


CD2 

CD1 

CDO 

DIVISORE 

0 

0 

0 

divide x 1 

0 

0 

1 

divide x 2 

0 

1 

0 

divide x 4 

0 

1 

1 

divide x 8 

1 

0 

0 

divide x 16 

1 

0 

1 

divide x 32 

1 

1 

0 

divide x 64 

1 

1 

1 

divide x 256 


Dividendo la frequenza del quarzo utilizzato dal 
micro prima per 13 poi per questo divisore si ot¬ 
tiene la frequenza di clock di trasmissione dati: 


Nota: La quantità di bits da trasmettere o ricevere 
ad ogni ciclo è legata naturalmente al tipo di pro¬ 
blematica che si vuole risolvere ed al tipo di inte¬ 
grati con i quali si vuole dialogare. È perciò ne¬ 
cessario consultare sempre i data-sheet degli in¬ 
tegrati o dei micro per non trovarsi poi in situazio¬ 
ni imprevedibili da cui non si sa più come uscire. 


Fclock = (Fquarzo in Hz : 13) : N.Divis. 

dove: 

Fclock è la frequenza del clock di trasmissione, 
Fquarzo è la frequenza del quarzo in hertz, 

13 è un numero fisso, 

N.Divis. è il numero del divisore (vedi Tabella n.2). 







































































Poniamo ad esempio il caso che un programma ri¬ 
chieda una frequenza di clock (Fclock) approssi¬ 
mativa di 9600 bit rate. 

Per trasmettere i dati da un micro ST6265 che u- 
tilizza un quarzo da 8 MHz ad un dispositivo e- 
sterno, potremo calcolare il numero del divisore 
utilizzando questa seconda formula: 

N.Divis. = (Fquarzo in Hz : 13) : Fclock 
(8.000.000 : 13) : 9600 = 64,10256 

Poiché i decimali non vanno considerati, per poter 
ottenere una frequenza approssimativa di clock di 
9600 bit rate dovremo dividere la frequenza del 
quarzo per 13 e successivamente per 64. 
Consultando la Tabella N.2 siamo ora in grado di 
sapere che per ottenere il divisore 64, i tre bits de¬ 
vono essere così settati: 


CD2 

CD1 

CD0 

1 

1 

0 


Nota: anche in questo caso, come nel preceden¬ 
te, sarà necessario consultare attentamente i da- 
ta-sheet dei dispositivi usati per poter selezionare 
correttamente la frequenza di clock ottimale o ne¬ 
cessaria con cui operare la trasmissione dati. 


Il registro spda o Spi Data Register è il registro in 
cui vengono memorizzati i dati ricevuti e i dati da 
trasmettere. 


7 

6 

5 

4 

3 

2 

1 

0 

D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 


Poiché è uno shift register, i dati vengono trasmessi 
e ricevuti a cominciare sempre dal Msb, cioè dal 
bit col valore significativo più alto. 

I dati vengono ricevuti e/o trasmessi da questo re¬ 
gistro ad ogni fronte (edge) di clock compatibil¬ 
mente a quanto settato come polarità e fase nei 
bits Cpol (0) e Cpha (5) del registro spmc, di cui 
già abbiamo parlato. Non è possibile modificare il 
contenuto di questo registro quando è attiva una 
trasmissione o una ricezione. 


D7-D0 bits 7-6-5-4-3-2-1 -0 = Data Bits. Questi bits 
contengono i valori ricevuti o da trasmettere. 


Poiché il registro spda è uno shift register, è ne¬ 
cessaria una certa cautela nell’utilizzarlo. 

Mettiamo ad esempio il caso che si vogliano tra¬ 
smettere ad un altro micro solo 4 bits e che il va¬ 
lore contenuto in spda prima della trasmissione sia 
179. La rappresentazione binaria è: 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

1 

0 

1 

1 

0 

0 

1 

1 


Quando, al primo fronte di clock, inizia la trasmis¬ 
sione, il registro shifta di un bit verso sinistra, quin¬ 
di DO assume valore 0 ed il valore contenuto in D7 
viene inviato sul piedino PC3 sout, che lo trasmette 
al micro slave. 

Questo micro lo riceve sul piedino PC2 sin e lo 
memorizza nel suo registro spda, partendo dal bit 
DO. Dopo la trasmissione del primo bit, la rappre¬ 
sentazione binaria del registro spda del micro ma¬ 
ster diventerà: 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

1 

1 

0 

0 

1 

1 

0 


Mentre quella del registro spda del micro slave è: 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

0 

0 

0 

0 

0 

1 


Al secondo fronte di clock, il registro shifta nuova¬ 
mente verso sinistra di un bit, quindi DO assume 
nuovamente valore 0 e D7 (che aveva assunto il 
valore di D6 dopo il primo fronte di clock) viene in¬ 
viato per essere trasmesso al piedino PC3 sout. 

Il micro slave riceve il dato sul piedino PC2 sin e 

10 memorizza nel registro spda sempre a partire 
dal bit DO, shiftando in DI, cioè verso sinistra, il va¬ 
lore prima contenuto in DO. 

11 ciclo descritto per la trasmissione dei primi due 
bits si ripete anche per i rimanenti 2 bits, come e- 
semplificato in fig.7. 


A fine trasmissione il registro spda del micro ma¬ 
ster ha questa rappresentazione binaria: 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

1 

1 

0 

0 

0 

0 


Come potete vedere il contenuto di questo registro 
è ora 48. Avendo trasmesso 4 bits, il registro è 
shiftato di 4 posizioni verso sinistra e i bits a de¬ 
stra sono stati riempiti con degli 0. 


A sua volta il registro spda del slave ha la seguente 
configurazione binaria: 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

0 

0 

1 

0 

1 

1 


Avendo ricevuto 4 bits, i primi quattro bits a destra 
hanno il valore indicato, che equivale all. 


Nel caso in cui si trasmetta un numero inferiore a 
8 bits, ricordate di fare molta attenzione perché, 
come avete visto dall’esempio, i 4 bits trasmessi a- 
vevano un valore di 88, mentre i 4 bits ricevuti han¬ 
no un valore di 11. 































































TRASMISSIONE DI 4 BUS 


MASTER SLAVE 

SPDA = 179 SPDA = 0 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

1 

0 

1 

1 

0 

0 

1 

1 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

0 

0 

0 

0 

0 

0 


INIZIO TRASMISSIONE 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

1 

1 

0 

0 

1 

1 

0 


i 


1°CLOCK 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

0 

0 

0 

0 

0 

1 




Per concludere, nel caso in cui siate in modalità 
master e dobbiate caricare un valore nel registro 
spda, non usate l’istruzione LDI, perché non ver¬ 
rebbe caricato nulla e trasmettereste 8 bits a zero. 
E’ invece necessario caricare prima il valore nell’ac¬ 
cumulatore A e successivamente muovere il con¬ 
tenuto dell’accumulatore in spda. 

Se ad esempio volessimo trasmettere 139, la se¬ 
quenza esatta delle istruzioni sarebbe: 

Idi a,139 

Id spda,a 



SPDA = 48 


FINE TRASMISSIONE 


SPDA = 11 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

1 

1 

0 

0 

0 

0 


D7 

D6 

D5 

D4 

D3 

D2 

DI 

DO 

0 

0 

0 

0 

1 

0 

1 

1 


Fig.7 Esempio di trasmissione-ricezione di 
4 bits. I dati vengono inviati a partire dal bit 
7 e ricevuti a partire dal bit 0. Ad ogni clock 
i dati shiftano verso sinistra. 


Il registro mise o Miscellaneous Register è un re¬ 
gistro comune a molti livelli di micro ST6 e quindi 
contiene dati per settare varie funzioni. 

Per la SPI viene utilizzato solo il bit 0. 


7 

6 

5 

4 

3 

2 

1 

0 








MO 


M0 bit 0 = Mode Sout. Se il piedino PC3 viene set¬ 
tato a 1 come Sout per la funzione SPI sarà attivo 
per la trasmissione dati. Se settato a 0 il PC3 di¬ 
venta un normale piedino di 1-0 di Port_C. 

A questo punto, conclusa la trattazione teorica sul¬ 
la SPI, non ci rimane che suggerirvi di realizzare 
subito le tre semplici interfacce periferiche pub¬ 
blicate in questo stesso numero per poter provare 
i programmi dimostrativi, da noi appositamente 
scritti, sulla trasmissione e ricezione di dati con lo 
standard SPI utilizzato dai micro ST62/65. 


Fig.8 Sulla rivista N.192 ab¬ 
biamo presentato un valido 
programmatore per i micro 
ST62/60 e ST62/65 che vi ser¬ 
virà per programmare questi 
nuovi microprocessori. 









































































































































































































































Sappiamo per esperienza che le spiegazioni pura¬ 
mente teoriche sono solitamente molto noiose e 
quasi sempre difficili da capire e da assimilare. 
Per questo, quando è possibile, cerchiamo di af¬ 
fiancare ad esse la realizzazione di circuiti pratici 
che, consentendoci di vedere quello che la teoria 
ci spiega, rendono tutto più comprensibile. 

Abbiamo quindi scritto alcuni programmi dimo¬ 
strativi sulla trasmissione e ricezione di dati con lo 
standard SPI utilizzato dai micro ST62/65, che si 
possono vedere in funzione montando 3 semplici 

interfacce periferiche. 

La prima interfaccia, siglata LX.1380, va innesta¬ 
ta nella scheda bus siglata LX.1329 (vedi fig.1), 
apparsa sulla rivista N.192, che molti tra voi a- 
vranno sicuramente già montato per poter testare 
le funzioni PWM ed EEprom. 


quarzo da 8 MHz, un pulsante, un deviatore, un 

trimmer e 8 diodi led, che vi consentiranno di sa¬ 
pere quale livello logico 0-1 è presente sulle usci¬ 
te del microprocessore che trasmette i dati. 

A seconda del programma che memorizzerete nel 
micro, potrete effettuare una trasmissione o una ri¬ 
cezione dati tra due micro ST62/65. 

Sulla terza interfaccia siglata LX.1382 (vedi fig.11), 
che deve essere collegata tramite una piattina 
all’interfaccia siglata LX.1380, dovrete montare 
quattro shift register HC/Mos tipo HCF.4094 o 
MC.14094 (vedi IC1-IC2-IC3-IC4), le reti resistive 
siglate R1-R2-R3-R4, tre display e otto diodi led. 
Sui display apparirà il dato ricevuto espresso col 
sistema decimale e sui diodi led il corrisponden¬ 
te valore espresso col sistema binario. 

Quando il numero binario corrisponde a 255 deci¬ 
male tutti i diodi led sono accesi, quando corri¬ 
sponde a 0 tutti i diodi led sono spenti. 


CIRCUITI test p« la SPI 


Grazie ai cinque programmi dimostrativi, che vi forniamo su richiesta 
insieme alle tre semplici interfacce presentate in queste pagine, non so¬ 
lo potrete sperimentare subito la trasmissione-ricezione dati con lo stan¬ 
dard SPI utilizzato dai micro ST62/65, ma avrete anche a disposizione 
delle utili “schede di valutazione” per testare immediatamente se i pro¬ 
grammi scritti da voi trasmettono e ricevono i dati correttamente. 


Come potete vedere dalla fig.4, l’interfaccia 
LX.1380 è molto semplice: sul suo circuito stam¬ 
pato vanno infatti montati un solo dip-switch prov¬ 
visto di 8 levette (vedi SI), un pulsante e due con¬ 
nettori maschi a 5+5 terminali che vi serviranno 
per collegare, con le apposite piattine, le due in¬ 
terfacce LX.1381 - LX1.382. 

Se non disponete ancora del bus siglato LX.1329, 
potrete richiederlo al nostro indirizzo assieme alla 
rivista N.192, nella quale potete trovare anche il 

Programmatore per i micro ST62/60 - ST62/65. 

La seconda interfaccia, siglata LX.1381, va colle¬ 
gata, sempre tramite la piattina che vi forniamo già 
cablata e completa di connettori femmina, sulla pri¬ 
ma interfaccia siglata LX.1380. 

Come potete vedere dalla fig.7, sull'Interfaccia 
LX.1381 vanno montati due zoccoli, uno per il mi¬ 
cro ST62/65 e l’altro per la rete resistiva R3, un 


Con questa scheda i dati trasmessi dal micro 
ST62/65 inserito nel bus LX.1329 o nell’interfaccia 
LX.1381 vengono ricevuti dai quattro shift register 
e visualizzati sui display e sui diodi led. 

REALIZZAZIONE PRATICA LX.1380 

Sul circuito stampato siglato LX.1380 dovete mon¬ 
tare tutti i componenti come disposti nel disegno vi¬ 
sibile in fig.4. 

Per iniziare vi consigliamo di inserire sul lato op¬ 
posto dello stampato in basso il CONN.1 a 1 fila 
24 terminali e in alto i due connettori a 1 fila 4 ter¬ 
minali, che vi consentiranno di collegare in modo 
stabile questa scheda all’interfaccia bus LX.1329. 
Proseguendo inserite anche i due connettori ma¬ 
schi a 5+5 terminali (vedi CONN.2) rivolgendo l’a¬ 
sola di riferimento verso l’alto. 

Al centro stagnate il pulsante PI e sotto questo il 
dip-switch siglato SI , rivolgendo il lato del corpo 
che riporta la scritta ON verso l’alto (vedi fig.4). 
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Fig.1 Sulla scheda bus LX.1329 presentata nella rivista N.192, che sicuramente avrete già 
montato, dovete inserire un micro ST62/65. Sopra a questa scheda andrà innestata l’in¬ 
terfaccia LX.1380, che vi permetterà di dialogare con le altre due interfacce siglate LX.1381- 
LX.1382. La scheda LX.1329 va alimentata tramite la scheda LX.1203. 



































































































Le 8 levette del dip-switch equivalgono agli 8 bits 
da configurare per la trasmissione dati. 

A questo proposito ricordate che la levetta all’e¬ 
strema destra rappresenta il bit 0 e quella all’e¬ 
strema sinistra il bit 7. 

REALIZZAZIONE PRATICA LX.1381 

Sul circuito stampato siglato LX.1381 vanno mon¬ 
tati tutti i componenti come visibile in fig.7. 

Iniziate inserendo i due zoccoli per la rete resiste¬ 
va R3 e per il micro ST62/65 (vedi IC1), poi in bas¬ 
so a destra inserite il CONN.2 rivolgendo la sua a- 
sola di riferimento verso l’alto. 

In alto stagnate gli 8 diodi led rivolgendo il termi¬ 
nale più lungo (vedi Anodo) verso R3. 

I dati ricevuti dal micro vengono visualizzati trami¬ 
te gli 8 diodi led e, come già spiegato a proposito 
dell’interfaccia LX.1380, tenete presente che il dio¬ 
do led più a destra corrisponde al bit 0 e il diodo 
led più a sinistra al bit 7. 

Quindi il diodo led all’estrema destra visualizzerà il 
dato configurato con la levetta più a destra del dip- 
switch della scheda LX.1380, e così via. 

Per completare il circuito stagnate il deviatore a le¬ 
vetta SI, il pulsante PI, il quarzo, il trimmer RI, i 
pochi condensatori e l’unica resistenza, così come 
appare nel disegno in fig.7. 

Ricordatevi che le tacche di riferimento a U della 
rete resistiva e del micro vanno rivolte a destra. 

II trimmer RI è stato inserito per applicare sull’in¬ 
gresso analogico PAO un valore di tensione varia¬ 
bile da 0 a 5 volt, in modo da farvi vedere il valo¬ 
re da 0 a 255 della conversione eseguita dall’A/D 

converter in un numero binario. 


REALIZZAZIONE PRATICA LX.1382 

Sul circuito stampato siglato LX.1382 inserite co¬ 
me primi componenti i 4 zoccoli per le reti resisti¬ 
vi e i 4 zoccoli per gli integrati shift register. 

In basso al centro inserite il CONN.2 rivolgendo la 
sua asola di riferimento verso l’alto. 

In alto stagnate gli 8 diodi led rivolgendo il termi¬ 
nale più corto (vedi K) verso i display. 

Come già spiegato a proposito del circuito prece¬ 
dente, anche in questo caso il diodo led più a de¬ 
stra visualizza il dato corrispondente al bit 0 ed il 
diodo led più a sinistra quello del bit 7. 

Per completare il montaggio innestate i tre display 
rivolgendo il punto decimale verso il basso. 

I PROGRAMMI nel DISCHETTO DF.1380 


Il dischetto siglato DF.1380, che forniamo a parte 
su richiesta, contiene 5 programmi: 


PROGOI - questo programma contiene un esem¬ 
pio di trasmissione dati tramite SPI da un micro 
ST62/65 a 4 shift register a 8 bits. Il micro in cui 
è stato caricato questo programma deve essere in¬ 
nestato nella scheda LX.1329 e i dati trasmessi 
vengono visualizzati sulla scheda LX.1382. 


TXPG02-RXPG02 - questi programmi contengono 
un esempio molto semplice di trasmissione dati fra 
2 micro ST62/65 tramite funzione SPI. Il micro in 
cui è stato caricato il programma Master (TXPG02) 
va inserito nella scheda LX.1329, mentre il micro 
in cui è stato caricato il programma Slave 
(RXPG02) nella scheda LX.1381. 


TXPG03-RXPG03 - questi programmi contengono 
un esempio abbastanza complesso di trasmissio- 



Fig.2 Questa è la foto della 
scheda LX.1380 provvista di 
un dip-switch, un pulsante e 
due connettori maschio per 
poter collegare le schede 
LX.1381-LX.1382 (vedi fig.1). 
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ELENCO COMPONENTI LX.1380 

RI = 22.000 ohm 

R2 = 22.000 ohm 

R3 = 22.000 ohm 

R4 = 22.000 ohm 

R5 = 22.000 ohm 

R6 = 22.000 ohm 

R7 = 22.000 ohm 

R8 = 22.000 ohm 

CI = 100.000 pF poliestere 

PI = pulsante 

SI = dip-switch 8 posizioni 

CONN.1 = connettore 24 poli 

CONN.2 = connettore 5+5 poli 


Fig.3 Schema elettrico deirinterfaccia LX.1380. 
Quando le levette del dip-switch SI sono poste in 
posizione ON (vedi fig.4), commutano sul livello 
logico 1 i piedini A0-A7 di porta A. 


PIATTINA 
LX.1381 o LX.1382 


PIATTINA 
LX.1381 o LX.1382 




Fig.4 Schema pratico 
della scheda LX.1380. 
Le asole dei connettori 
CONN.2 vanno rivolte 
verso l’alto. Le levette di 
SI corrispondono ai 
piedini di porta A (vedi 
fig.3) secondo la nume¬ 
razione presente sulla 
serigrafia dello stam¬ 
pato, quindi non consi¬ 
derate la numerazione 
presente sul dip-switch. 
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ne/ricezione dati tramite SPI che coinvolge due mi- 
cro ST62/65 e 4 shift register. 

In sostanza il micro contenente il programma Sla¬ 
ve (RXPG03), innestato nella scheda LX.1329, rie¬ 
sce a ricevere i dati dal micro contenente il pro¬ 
gramma Master (TXPG03), innestato nella scheda 
LX.1381, e li ritrasmette, sfalsati da un solo ciclo 
di trasmissione, ai 4 shift register che si trovano 
sulla scheda LX.1382 sfruttando lo stesso segna¬ 
le di clock trasmesso dal Master. Naturalmente l’u¬ 
nica condizione è che i tre dispositivi abbiano il se¬ 
gnale del clock SPI in comune. 

Poiché nel dischetto DF.1380 tutti questi program¬ 
mi sono in formato .ASM, dovrete necessariamen¬ 
te assemblarli in modo da ottenere dei files in for¬ 
mato .HEX (vedi rivista N.179), prima di poterli ca¬ 
ricare sui micro ST62/65 tramite il programmatore 
LX.1325 descritto nella rivista N.192. 

Accanto ad ogni istruzione di programma abbiamo 
inserito un commento chiarificatore, quindi se a- 
vete qualche dubbio potete aprire i files con un 
qualsiasi editor e leggere le spiegazioni. 

È sottinteso che per effettuare questi test è consi¬ 
gliabile usare dei micro ST62E65 provvisti di fine¬ 
stra perché si possono cancellare e quindi riuti¬ 
lizzare, mentre i micro ST62T65 si possono pro¬ 
grammare una volta sola. 

La scheda LX.1380 va innestata sulla scheda bus 
LX.1329 e dovrete necessariamente alimentarla 
con una tensione stabilizzata di 5 volt. 

La fig.1 potrà chiarire su quale dei tre poli presen¬ 
ti sulla morsettiera dovrete inserire il positivo ed il 
negativo dei 5 volt. 

Il programma PROGOI 

Dopo aver assemblato il file PROGOI .ASM in 
PROGOI .HEX, caricate questo programma su un 
micro ST62E65 che inserirete nella scheda bus si¬ 
glata LX.1329. 

Eseguita questa operazione collegate la scheda 
LX.1380 alla scheda bus LX.1329 tramite il con¬ 
nettore CONN.1 e la scheda LX.1382 alla scheda 
LX.1380 tramite piattina utilizzando a vostro pia¬ 
cere il CONN.2 a destra o quello a sinistra. 

Spostate a vostro piacere una o più leve del dip- 
switch presente nella scheda LX.1380 e non ap¬ 
pena premerete il pulsante PI la configurazione se¬ 
lezionata sul dip-switch verrà inviata tramite la SPI 
alla scheda siglata LX.1382. 

Sui diodi led apparirà il valore binario degli 8 bits 
selezionati tramite dip-switch e sui display appa¬ 
rirà l’equivalente valore decimale. 


Il programma PROGOI è un esempio di come ri¬ 
sulti possibile trasmettere dei dati tramite SPI da 
un micro ST62/65 a 4 shift register a 8 bits di ti¬ 
po HC/Mos 4094 collegati in serie. 

Gli shift register (vedi IC1-IC2-IC3-IC4) pur non 

disponendo della funzione SPI ricevono i dati in 
modo seriale sul piedino 2 ed il segnale di clock 
sul piedino 3 (vedi fig.9). 

I dati ricevuti vengono successivamente memoriz¬ 
zati e visualizzati in questi registri solo inviando un 
segnale di latch (high) sul piedino 1. 

Infatti, solamente quando questo piedino passa 
dallo stato logico 0 allo stato logico 1, i dati pre¬ 
senti in quell’istante nel registro vengono memo¬ 
rizzati e contemporaneamente inviati in modalità 
parallela su 8 dei suoi piedini (per la precisione i 
piedini 4-5-6-7-14-13-12-11) per essere visualizza¬ 
ti sui display e sui led della scheda. 

II collegamento in serie degli integrati 4094 è sta¬ 
to ottenuto collegando il piedino 9 del primo di¬ 
spositivo al piedino 2 del secondo e così via. 

I dati inviati passano perciò di volta in volta dal pri¬ 
mo registro al secondo fino a quando non viene in¬ 
viato il segnale di latch. 

I programmi TXPG02 - RXPG02 

Dopo aver assemblato il programma TXPG02.A- 
SM ottenendo TXPG02.HEX ed il programma 
RXPG02.ASM ottenendo RXPG02.HEX, dovrete 
caricarli su due micro cancellabili tipo ST62E65. 










Fig.6 Schema elettrico del cir¬ 
cuito LX.1381. Gli 8 diodi led 
collegati al micro si accende¬ 
ranno con lo stesso codice bi¬ 
nario impostato col dip-switch 
SI montato sull'Interfaccia pe¬ 
riferica LX.1380 (vedi fig.4). 


ELENCO COMPONENTI LX.1381 

RI = 10.000 ohm trimmer 
R2 = 10.000 ohm 
R3 = 330 ohm rete resist. x 8 
CI = 100.000 pF poliestere 
C2 = 100.000 pF poliestere 
C3 = 22 mF elettrolitico 
C4 = 100.000 pF poliestere 
C5 = 1 mF elettrolitico 
C6 = 22 pF ceramico 
C7 = 22 pF ceramico 
DL1-DL8 = diodi led 
IC1 = micro ST62/65 
XTAL1 = quarzo 8 MHz 
PI = pulsante 
SI = deviatore 

CONN.2 = connettore 5+5 poli 
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Fig.7 Schema pratico di montaggio della scheda 
LX.1381. Ricordate che la levetta del deviatore SI de¬ 
ve essere rivolta su A quando userete i programmi 
TXPG02-RXPG02 e su B quando userete i programmi 
TXPG03-RXPG03 (leggete il testo). 



VERSO LX.1380 















































































Sul micro in cui avete caricato il programma 
TXPG02 attaccate un’etichetta con la scritta TX02 
(master), mentre sul micro in cui avete caricato il 
programma RXPG02 attaccate un’etichetta con la 
scritta RX02 (slave). 

Il micro TX02 va innestato nella scheda LX.1329, 
mentre il micro RX02 nella scheda LX.1381. 
Eseguite queste operazioni collegate la scheda 
LX.1380 alla scheda bus LX.1329 tramite il con¬ 
nettore CONN.1 e la scheda LX.1381 alla scheda 
LX.1380 tramite piattina utilizzando a vostro pia¬ 
cere il CONN.2 a destra o quello a sinistra. 

IMPORTANTE: il deviatore SI presente sul circui¬ 
to LX.1381 va posizionato verso A in modo da col¬ 
legare il piedino 26 (PC2) del micro Slave con il 
piedino 25 (PC3) del micro Master, diversamente 
non verrà effettuata nessuna trasmissione dati. 
Nella fig.8 potete vedere la piedinatura elettrica e 
logica del micro ST62/65. 

Questi due programmi offrono un esempio di tra¬ 
smissione dati tra 2 micro ST62/65 tramite la fun¬ 
zione SPI. 

Vi facciamo notare che il pulsante PI che si trova 
sulla scheda LX.1380 è inattivo, mentre è attivo 
il pulsante PI ed inattivo il trimmer RI presenti 
nella scheda LX.1381. 

Più avanti spiegheremo nei particolari le istruzioni 
specifiche della SPI presenti in questi programmi. 
Voi stessi leggendo i sorgenti potrete verificare 
che la trasmissione e la ricezione dei dati non è 
continua, ma avviene solo quando il programma 
RXPG02 (Slave) ne fa richiesta. 


Per il momento vi diciamo solo di concentrare l’at¬ 
tenzione sulla configurazione del registro spmc, 
tramite il quale è stata attivata la Start Condition. 

Compito del programma TXPG02-Master è legge¬ 
re la configurazione del dip-switch presente nella 
scheda LX.1380 per trasmetterla al programma 

RXPG02-Slave. 

Questo programma, dopo aver ricevuto i dati, li vi¬ 
sualizza con gli 8 diodi led presenti sul circuito. 
Nell’esempio che abbiamo scritto, la trasmissione 
dati avviene soltanto quando viene premuto il pul¬ 
sante PI presente nella scheda LX.1381. 

In sostanza dunque è il programma Slave che, ri¬ 
levando la pressione esercitata sul pulsante, invia 
al programma Master la richiesta di trasmissione. 

I programmi TXPG03 - RXPG03 

Dopo aver assemblato il programma TXPG03.A- 
SM ottenendo TXPG03.HEX ed il programma 
RXPG03.ASM ottenendo RXPG03.HEX, dovrete 
caricarli su due micro cancellabili tipo ST62E65. 
Sul micro in cui avete caricato il programma 
TXPG03 applicate un’etichetta con la scritta TX03 
(master), mentre nel micro in cui avete caricato il 
programma RXPG03 applicate un’etichetta con la 
scritta RX03 (slave). 

Il micro RX03 va inserito nella scheda LX.1329, 
mentre il micro TX03 nella scheda LX.1381. 
Eseguite queste operazioni collegate la scheda 
LX.1380 alla scheda bus LX.1329 tramite il con¬ 
nettore CONN.1 e la scheda LX.1381 alla scheda 
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ST 62/65 


Fig.8 A sinistra lo schema a blocchi de¬ 
gli stadi presenti nel micro ST62/65 e a 
destra la sua zoccolatura. 


































































































LX.1380 tramite piattina utilizzando a vostro pia¬ 
cere il CONN.2 a destra o quello a sinistra. 

Per finire collegate sempre tramite piattina anche 
la scheda LX.1382 alla scheda LX.1380 sul con¬ 
nettore rimasto libero. 

IMPORTANTE: il deviatore SI presente sul circui¬ 
to LX.1381 va posizionato verso B in modo da col¬ 
legare il piedino 26 (PC2) del micro TX03 con il pie¬ 
dino 27 (PCI) del micro RX03, diversamente non 
avverrà nessuna trasmissione dati. 

Anche in questo caso il pulsante PI presente sul¬ 
la scheda LX.1380 è inattivo e lo stesso dicasi per 
il pulsante PI presente sulla scheda LX.1381. 
Quello che risulta attivo è il solo trimmer RI che 
ci serve per variare la tensione sul piedino 10 uti¬ 
lizzato come A/D converter. 

Noi abbiamo utilizzato un trimmer, ma potrete en¬ 
trare su questo piedino con qualsiasi tensione con¬ 
tinua da 0 a 5 volt massimi prelevabili da una sor¬ 
gente qualsiasi, una fotoresistenza, una resisten¬ 
za NTC, un alimentatore ecc. 

In pratica il programma Master rileva il valore di 
tensione leggendolo sul piedino 10 del micro TX03 
e, passando attraverso il micro RX03 Slave situa¬ 
to sulla scheda LX.1329, lo visualizza sui diodi 
led della scheda LX.1382 con un codice binario e 
sui tre display in un valore decimale da 0 a 255. 

In questo caso la trasmissione dati tra due micro 
e tra il micro e gli shift register avviene utilizzando 

10 stesso clock del micro Master. 

Unica condizione è, ovviamente, che i piedini PC4 
Sck dei micro ed i piedini 3 degli shift register sia¬ 
no collegati insieme. 

11 micro TX03 legge per 32 volte la tensione pre¬ 
sente sul piedino dell’A/D converter, ne fa il tota¬ 
le ed il numero binario che ne risulta lo divide per 
32 in modo da ottenere un valore medio. 

Questo valore medio viene poi convertito in un co¬ 
dice BCD da 3 bytes, che, inviato alla scheda 
LX.1382, ci servirà per far apparire sui display un 
numero decimale. 

A differenza dei programmi precedenti, in questo 
esempio non abbiamo attivato la Start Condition 
tramite il registro Mode spmc, ma viene invece ef¬ 
fettuato un controllo sul piedino PC2 di Port_C tra¬ 
mite l’istruzione JRR. 

Infatti solo quando il micro TX03 riceve un impul¬ 
so di reset sul suo piedino 26 (PC2 Sin), inizia a 
trasmettere i dati per un totale di 5 cicli di tra¬ 
smissione di 8 bits ciascuno. 

Per tutta la durata della trasmissione si accende il 
diodo led posto a sinistra. 


Lo stesso micro controlla inoltre che il numero bi¬ 
nario non superi una soglia che possiamo prefis¬ 
sare tra 1 e 255: nel nostro esempio abbiamo pre¬ 
fissato la soglia a 230. 

Se questo numero viene superato, il Master invia 
un segnale di allarme sul piedino 14, corrispon¬ 
dente al piedino logico PA2 di porta A del micro 
TX03 (vedi fig.8), collegato al piedino NMI del mi¬ 
cro RX03, presente nella scheda LX.1329, e cari¬ 
ca un livello logico 1 nella variabile nonesi, che 
è normalmente a livello logico 0. 

Nel programma è stata inserita una routine che si 
attiva quando viene letto un dato superiore a 230. 
Con questa routine viene abbassato il tempo di ri¬ 
chiesta invio dati da 10 secondi ad 1 secondo, fi¬ 
no a che il valore medio rilevato sul trimmer non 
torna sotto il limite dei 230. 

Il superamento del livello di soglia è per noi anche 
visivo perché il diodo led posto a sinistra comincia 
a lampeggiare molto più velocemente, all’incirca 1 
volta al secondo. 

Il programma RX03, presente sulla scheda bus 
LX.1329, utilizza un orologio interno generato tra¬ 
mite la funzione Timer e ogni 10 secondi invia al 
micro TX03, presente sulla scheda LX.1381, una 
richiesta di invio dati relativa appunto alla codifica 
digitale della tensione rilevata sul trimmer RI. 

Pur essendo RX03 settato in ricezione, avendo ca¬ 
ricato il valore 1 sul registro mise, il suo piedino 25 
diventa un piedino settato in trasmissione come 

PC3 Sout. 

Come già sapete, questo significa che in presenza 
di un clock SPI, il valore presente di volta in volta 
sul bit 7 del registro spda viene trasmesso su PC3 
Sout e nel nostro caso inviato agli shift register 
montati sulla scheda LX.1382. 

Quindi ogni 10 secondi si ha una ricezione dati 
suddivisi in 5 cicli di 8 bits ciascuno. 

Poiché qualcuno si chiederà perché occorrono 5 
cicli cercheremo di spiegarvelo: 

- al 1 0 ciclo gli 8 bits presenti nel registro spda 
del micro TX03 vengono trasferiti nel registro sp¬ 
da del micro RX03 e qui rimangono parcheggiati. 

- al 2° ciclo i successivi 8 bits presenti nel regi¬ 
stro spda del micro TX03 vengono inviati nel regi¬ 
stro spda del micro RX03, mentre gli 8 bits del 1 ° 
ciclo vengono inviati tramite PC3 Sout all’integra¬ 
to IC1 della scheda LX.1382. 

Nel registro spda del micro RX03 risultano ora par¬ 
cheggiati gli 8 bits del 2° ciclo. 


DISPLAY1 DISPLAY2 DISPLAY3 



Fig.9 Schema elettrico del circuito LX.1382. Con il programma PROGOI la configurazione 
selezionata con il dip-switch SI presente sulla scheda LX.1380 verrà inviata su questa 
scheda per essere visualizzata tramite gli otto diodi led e i tre display. 


ELENCO COMPONENTI LX.1382 

RI = 330 ohm rete 

DL1-DL8 = diodi led 

DISPLAY1 = display TIL.702 

R2 = 330 ohm rete 

DISPLAY2 = display TIL.702 

R3 = 330 ohm rete 

DISPLAY3 = display TIL.702 

R4 = 330 ohm rete 

IC1 = C/Mos tipo 4094 

CI = 100.000 pF poliestere 

IC2 = C/Mos tipo 4094 

C2 = 100.000 pF poliestere 

IC3 = C/Mos tipo 4094 

C3 = 100.000 pF poliestere 

IC4 = C/Mos tipo 4094 

C4 = 100.000 pF poliestere 

CONN.2 = connettore 5+5 poli 


- al 3° ciclo i successivi 8 bits presenti nel regi¬ 
stro spda del micro TX03 vengono inviati nel regi¬ 
stro spda del micro RX03, gli 8 bits del 2° ciclo 
vengono inviati sempre con PC3 Sout all’integrato 
IC1 della scheda LX.1382 e gli 8 bits del 1 ° ciclo 
vengono trasferiti ad IC2. 

Nel registro spda del micro RX03 risultano ora par¬ 
cheggiati gli 8 bits del 3° ciclo. 

- al 4° ciclo i successivi 8 bits presenti nel regi¬ 
stro spda del micro TX03 vengono inviati nel regi¬ 
stro spda del micro RX03, gli 8 bits del 3° ciclo 
vengono inviati con PC3 Sout all’integrato IC1 del¬ 
la scheda LX.1382, gli 8 bits del 2° ciclo vengono 
trasferiti ad IC2 e gli 8 bits del 1 ° ciclo vengono 
trasferiti ad IC3. 


Nel registro spda del micro RX03 risultano ora par¬ 
cheggiati gli 8 bits del 4° ciclo. 

- al 5° ciclo i successivi 8 bits presenti nel regi¬ 
stro spda del micro TX03 vengono inviati nel regi¬ 
stro spda del micro RX03, gli 8 bits del 4° ciclo 
vengono inviati con PC3 Sout all’integrato IC1 del¬ 
la scheda LX.1382, gli 8 bits del 3° ciclo vengono 
trasferiti ad IC2, gli 8 bits del 2° ciclo vengono tra¬ 
sferiti ad IC3 e gli 8 bits del 1 ° ciclo vengono tra¬ 
sferiti ad IC4. 

Se ci fossimo fermati alla trasmissione del 4° ci¬ 
clo, questo sarebbe rimasto parcheggiato nel re¬ 
gistro spda del micro RX03 e non avrebbe rag¬ 
giunto la scheda LX.1382. 








































































Fig.10 Foto della scheda test 
LX.1382. Poiché questa è la 
foto di un prototipo, sul cir¬ 
cuito stampato manca il dise¬ 
gno serigrafico. 
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Fig.11 Schema pratico di montaggio del¬ 
la scheda LX.1382. Il terminale più cor¬ 
to dei diodi led (vedi terminale K) va ri¬ 
volto in basso verso i tre display. 



VERSO LX.1380 














































































A questo punto il micro RX03 lancia il segnale di 
latch e tutti i dati presenti nei 4 shift register ven¬ 
gono visualizzati sui display e sui led. 

I Programmi TXPG02 e RXPG02 
ISTRUZIONE per ISTRUZIONE 

Le possibilità offerte dalla funzione SPI sono mol¬ 
teplici, ma non potendo fare un articolo fiume che 
contemplasse tutte le casistiche necessarie ad il¬ 
lustrarle, abbiamo realizzato i programmi di esem¬ 
pio di cui avete appena letto una sintetica descri¬ 
zione. Oltre a permettervi di sperimentare subito la 
SPI, potranno servirvi per testare un programma 
scritto da voi. 

Ad esempio, caricando sul circuito Master il vostro 
programma e sul circuito Slave il nostro RXPG02, 
sarete in grado di valutare immediatamente se il 
vostro programma “trasmette” i dati correttamente. 
Stessa cosa potrete fare per testare un vostro pro¬ 
gramma in ricezione. 

Proprio perché potete disporre di una sorta di sche¬ 
da di valutazione, abbiamo pensato di analizzare 
nei particolari le istruzioni dei programmi denomi¬ 
nati TXPG02 ed RXPG02, fermo restando che po¬ 
trete utilizzare come test anche gli altri programmi 
scritti da noi. 

Inoltre, per focalizzare la vostra attenzione sull’ar¬ 
gomento che stiamo trattando, ometteremo di se¬ 
guito la spiegazione delle istruzioni non inerenti al¬ 
la funzione SPI, ampiamente trattate nel corso del¬ 
le precedenti lezioni. 

Innanzitutto con i programmi RX e TX noi leggia¬ 
mo i livelli logici presenti sulla porta A del micro 
Master inserito nel Bus LX.1329 e li inviamo con 
la funzione SPI al micro Slave inserito nella sche¬ 
da LX.1381. Quando infatti, il deviatore presente 
su questa scheda è posizionato su A, collega il pie¬ 
dino 26 (PC2 Sin) del circuito LX.1381 al piedino 
25 (PC3 Sout) del circuito LX.1329. 

I livelli logici della porta A possono essere modifi¬ 
cati a piacere tramite il dip-switch SI. 

Facciamo presente che il micro Master invia i dati 
dei suoi 8 bits alla velocità di 2.400 bits rate verso 
il micro Slave ogni volta che premiamo il pulsante 
PI montato sulla scheda LX.1381, cioè quando il 
programma Slave fa una richiesta di trasmissione. 

Appena il micro Slave riceve i dati dal micro Ma¬ 
ster li carica sulla sua porta B e li visualizza sugli 
8 led secondo questa logica: 

Livello logico 1 = diodo led acceso 
Livello logico 0 = diodo led spento 


Analizziamo ora il programma caricato sul micro 
Master chiamato TXPG02. In Data Space trovia¬ 
mo le istruzioni dei registri utilizzati per la SPI: 

mise .def Oddh 

spda .def OeOh 

spdv .def Oel h 

spmc .def 0e2h 

1 piedini della porta A gestiti dal dip-switch risul¬ 
tano configurati Input Pull-Up senza Interrupt. 

Idi port_a,00000000b 

Idi pdir_a,00000000b 

Idi popt_a,00000000b 

A questo proposito vi ricordiamo che i piedini di 

Port_A corrispondono alle levette del dip-switch 
come qui sotto riportato: 

Idi port_a, 0000000 Ob 
SI 01234567 

Ora passiamo ai piedini di Port_C che, per gestire 
in modalità corretta la SPI, vanno così configurati: 

Idi port_c,000001 OOb 

Idi pdir_c,000110OOb 

Idi popt_c,00011000b 

Il piedino 2 viene configurato Input no Pull_up, 
mentre i piedini 3-4 come Output Push_pull. 

In questo esempio di trasmissione i restanti piedini 
non ci interessano quindi non li abbiamo riportati. 
Con le istruzioni appena viste abbiamo solamente 
predisposto i piedini interessati alla trasmissione, 
ma non abbiamo ancora attivato la SPI. 

In questo programma il piedino 2 è stato configu¬ 
rato come input, perché dovrà ricevere dal micro 
Slave il segnale necessario al micro Master per i- 
niziare la trasmissione ed avere così una sorta di 
sincronismo tra i due microprocessori. 

Se non è necessario alcun sincronismo, il piedino 

2 può essere anche ignorato e non configurato nel 
programma Master. 

Dal momento che in questo programma non ven¬ 
gono utilizzati, tutti i registri di interrupt sono così 
configurati: 

Idi armc,00000000b 

Idi adcr,00000000b 

Idi tscr,00000000b 

Idi ior,00000000b 

Ora passiamo al programma principale e analiz¬ 
ziamo, per quanto riguarda la trasmissione dei da¬ 
ti, le istruzioni riga per riga: 

main Idi wdog,0ffh 


Fig.12 Dopo aver innestato la 
scheda LX.1380 sulla scheda 
LX.1329, per collegare le altre 
due schede potrete usare le 
piattine cablate che abbiamo 
inserito nel kit. 



Provvede ad assegnare all’etichetta main questa 
istruzione che ricarica il watchdog. 

Idi misc,1 

Come abbiamo spiegato, mettendo a 1 il bit 0 di 
mise, il piedino 3 di Port_C passa dallo stato di I- 
O a PC3 Sout e diventa il piedino di trasmissione 
della funzione SPI. 

Attenzione: vi ricordiamo che se non inserite que¬ 
sta istruzione, anche configurando il registro spmc 
in Master Mode, la trasmissione dei dati non av¬ 
verrà mai e il clock di trasmissione su PC4 Sck 
non partirà mai. 

La successiva istruzione: 

Idi spdv,01000111b 

serve per configurare il registro spdv con la mo¬ 
dalità di trasmissione di 8 bits per ciclo alla velo¬ 
cità di 2400 bits rate. 

Se avete letto la spiegazione dei registri e avete 
visto le tabelle riportate a pag.109 di questa rivista, 
avrete capito perché abbiamo caricato questo va¬ 
lore nel registro spdv. 


L’istruzione che segue, cioè: 

Idi spmc,000101 OOb 

carica nel registro spmc i valori di configurazione 
Master per la trasmissione dati e seleziona la mo¬ 
dalità Clock Master mode con polarità e fase nor¬ 
mali. Non è previsto un filtro in trasmissione e il 
bit 2 Spstrt posto a 1 serve a gestire assieme al 
bit 7 Sprun la condizione di Start trasmissione-ri¬ 
cezione. Inoltre il bit 7 Sprun è stato messo mo¬ 
mentaneamente a 0. Infatti ponendolo a 1 avrem¬ 
mo attivato la condizione di Start trasmissione-ri¬ 
cezione e se durante la fase iniziale di configura¬ 
zione dei due micro fosse stato inviato un falso se¬ 
gnale sul piedino PC2 del Master, questi avrebbe 
iniziato a trasmettere con il programma Slave non 
ancora pronto a ricevere i dati. 

Se andate a rileggere quanto spiegato per questo 
registro potrete verificare personalmente quanto 
detto in proposito. 

Ora passiamo alla successiva istruzione: 

pippo Idi wdog,0ffh 















La label pippo viene associata all’Istruzione che ri¬ 
carica il watchdog. 

Id a,port_a 

Id spda,a 

Come già ribadito, questa è la sequenza giusta per 
caricare nel registro spda il valore da trasmettere. 
Nel nostro caso muoviamo il valore logico presen¬ 
te sugli 8 piedini di Port_A nel registro spda. 

set 7,spmc 

Mettendo a 1 il 7 bit (Sprun) del registro spmc, 
abbiamo predisposto tutto per la trasmissione del 
valore presente su porta A, ma non abbiamo ini¬ 
ziato ancora la trasmissione. Infatti come già ripe¬ 
tuto oramai varie volte, settando Sprun e Spstrt 
abbiamo creato la condizione di start. 

In questa condizione tutto è pronto per la trasmis¬ 
sione, che avviene però solamente quando sul pie¬ 
dino 2 di Porta C viene rilevato un fronte di salita 

o rising edge. 

Questo segnale verrà generato dal micro Slave e 
vi sarà spiegato nel programma RXPG02. 

Una cosa che vale la pena sottolineare è che non 
dovremo inserire nessuna istruzione o routine per 
verificare la presenza del segnale rising edge sul 
piedino 2 di porta C, ma sarà automaticamente ri¬ 
levato dal micro Master che provvederà, sempre 
automaticamente, ad iniziare la trasmissione. 

Con l’istruzione seguente: 

pluto Idi wdog,0ff 

abbiamo assegnata la label pluto ad un’istruzione 
che ricarica il watchdog. 

jrs 7,spmc,pluto 

Con questa istruzione il programma esegue un 
“loop” e salta a pluto finché il bit 7 (Sprun) è set¬ 
tato. In pratica il programma rimane in loop finché 
non è avvenuta la trasmissione. Quando la tra¬ 
smissione è terminata, il bit 7 di spmc viene au¬ 
tomaticamente resettato. 

ÌP P'PPO 

Questa istruzione viene eseguita solo a trasmis¬ 
sione terminata ed il programma salta perciò nuo¬ 
vamente a pippo dove ricaricherà un eventuale 
nuovo valore in spda (se sono stati modificati i dip- 
switch) e si preparerà di nuovo a trasmetterlo. 


Avrete già sicuramente notato, ma lo evidenziamo 
ugualmente, che il programma TXPG02 così come 
è stato scritto, invia al micro slave sempre la pe¬ 
nultima configurazione presente in porta A, mai l’ul¬ 
tima. Non è un errore, ma solamente la necessità 
di scrivere un programma semplice e breve. 

Una gestione più complessa avrebbe potuto crea¬ 
re altri problemi e non ci avrebbe permesso di fo¬ 
calizzare bene la SPI. 

Vediamo ora il programma RXPG02 caricato sul 
micro Slave. 


Passiamo subito al 

da Porta A: 

settaggio delle porte iniziando 

Idi 

port_a,00000000b 

Idi 

pdir_a,00000000b 

Idi 

popt_a,00000000b 


Il piedino 0 viene configurato Input Pull-up per ge¬ 
stire la pressione del pulsante PI. 

Questo pulsante servirà per inviare la richiesta al 
micro Master di inizio trasmissione dati. 

A seguire viene configurata Porta B: 

Idi port_b,00000000b 

Idi pdir_b,11111111b 

Idi popt_b,11111111b 

Tutti gli 8 piedini di questa porta sono configurati 
come Out Push-pull. A questa porta sono stati col¬ 
legati 8 leds per rendere possibile la visualizza¬ 
zione dei dati ricevuti con la SPI. 

Al piedino 1 è stato collegato il led 0, al piedino 2 
il led 1 e così via (vedi fig.6). 

Infine configuriamo Porta C: 

Idi port_c,00010100b 

Idi pdir_c,00001 OOOb 

Idi popt_c,00001 OOOb 

Il piedino 2 viene configurato come Input No Pull- 
up No Interrupt e riceve i dati trasmessi da PC3 
Sout del Master. 

Il piedino 3 serve solo per inviare il segnale di ri¬ 
chiesta dati al micro Master e viene perciò confi¬ 
gurato come Out Push-pull. 

Il piedino 4 infine viene configurato come Input No 
Pull-up No Interrupt e riceve il clock di trasmis¬ 
sione dal rispettivo piedino PC4 Sck del Master. 
Anche in questo caso non abbiamo ancora attiva¬ 
to la SPI, ma solamente predisposto i piedini inte¬ 
ressati alla ricezione dati. 

In questo programma è prevista la gestione di un 
interrupt, ma per il momento carichiamo i registri 


relativi tutti a zero per evitare in questo modo atti¬ 
vazioni premature: 

Idi armc,00000000b 

Idi adcr,00000000b 

Idi tscr,00000000b 

Idi ior,00000000b 

L’interrupt da gestire in questo programma è quello 
su SPI per fine ricezione dati (ricordate il bit 6 Spie 
del registro spmc spiegato nell’articolo teorico a 
pag.107), quindi prima del programma principale in¬ 
seriamo la routine per gestire questo interrupt. 


res 

3,port_c 

Idi 

wdog,0ffh 

Id 

a,spda 

Id 

port_b,a 

res 

7,spdv 

reti 



Questa routine viene attivata quando la ricezione 
dati è terminata e svolge la seguente funzione: 

res 3,port_c 

trasmette cioè subito un segnale falling edge (fron¬ 
te di discesa) tramite il piedino 3 di Port_C al mi- 
cro Master, cosicché il relativo piedino 2 si troverà 
a livello logico 0 e sarà ripristinata la condizione di 
start di trasmissione già spiegata per il programma 
TXPG02. 

Idi wdog,0ffh 

Questa istruzione ricarica il watchdog. 

Id a,spda 

Id port_b,a 

La ricezione è terminata, quindi il registro spda 
contiene il valore del dato ricevuto e trasmesso dal 
Master. Per visualizzarlo tramite gli 8 leds lo dob¬ 
biamo caricare su porta B e per questo utilizziamo 
l’accumulatore a. 

res 7,spdv 

Il bit 7 del registro spdv, come già spiegato, si set¬ 
ta automaticamente a 1 all’attivazione dell’interrupt 
e quindi prima di uscire dalla routine relativa sarà 
nostra cura portarlo a 0 . 

reti 

Conoscete oramai tutti la sua funzione. 

Definita e spiegata questa routine di interrupt si 
passa ora al programma principale: 

mairi Idi wdog,0ffh 


Assegna come sempre l’etichetta main alla relati¬ 
va istruzione che ricarica il watchdog. 

res 3,port_c 

Questa istruzione è, come vedete bene, identica a 
quella inserita nella routine di interrupt, ed ha lo 
stesso scopo. 

Idi misc,0 

Mettendo a 0 il bit 0 del registro mise noi riportia¬ 
mo il piedino 3 di porta C a normale piedino di 1-0 
e non più PC3 Sout di SPI. 

Se per errore lo avessimo settato a 1 in questo pro¬ 
gramma specifico, i dati che mano a mano veni¬ 
vano ricevuti su PC2 Sin e caricati bit per bit sul 
registro spda, con la stessa sequenza sarebbero 
stati ritrasmessi sul piedino 3 di porta C (PC3 Sout) 
creando probabilmente un notevole caos. 

Idi spdv,01000111b 

Con questa istruzione configuriamo il registro spdv 
e quindi la ricezione dati sarà di 8 bits alla velocità 

di 2400 bit rate. 

Come avrete notato, abbiamo inserito le identiche 
modalità del programma TXPG02, anche se nel ca¬ 
so della velocità è completamente superfluo dal 
momento che la ricezione dei dati avviene sul fron¬ 
te del clock presente sul piedino PC4 Sck e quin¬ 
di “comanda” sempre la frequenza del Master. Se 
ad esempio avessimo scritto: 

Idi spdv,010001 lOb 

che corrisponde ad una velocità di ricezione di 9600 
bits rate (vedi Tabella N.2 nella rivista N.198), la ri¬ 
cezione sarebbe avvenuta comunque a 2400 bits 
rate, dal momento che Master trasmette con un 
clock di 2400 bits rate. Comunque, nel caso di dia¬ 
logo tra due microprocessori, per coerenza tra i da¬ 
ti conviene sempre definire un’identica velocità di 
trasmissione e di ricezione. 

Per il numero dei bit da ricevere è invece assolu¬ 
tamente necessario definirli sempre uguali al nu¬ 
mero dei bit da trasmettere altrimenti potrebbero 
sorgere grossi problemi di valorizzazione dati. 
Infatti, se ricordate, la trasmissione finisce quando 
sono stati trasmessi un numero di bits pari a quel¬ 
lo indicato nel registro spdv del programma Ma¬ 
ster e stessa cosa vale anche per la ricezione do¬ 
ve vengono ricevuti un numero di bits pari a quel¬ 
lo indicato nel registro spdv del programma Slave. 
Questo significa che se i due valori non sono u- 
guali la trasmissione dei dati potrebbe durare più 


della ricezione e viceversa e vi lasciamo immagi¬ 
nare quali valori strani potreste ritrovare nel regi¬ 
stro spda al termine di tutto ciò. 

Idi spmc,01001000b 

In questo modo il registro spmc viene caricato con 
valori di configurazione Slave per la ricezione dati. 
Viene selezionata la modalità Clock Slave mode, 
con polarità e fase normali e senza filtri in rice¬ 
zione. Notate che il bit 7 Sprun è stato caricato a 
0 : questo sta a significare che, per il momento, non 
abbiamo dato inizio a nessuna ricezione dati. 
Inoltre abbiamo attivato la richiesta di interrupt SPI 
settando a 1 il bit 6 Spie. 

Pertanto, tutte le volte che verrà rilevata la fine ri¬ 
cezione, il programma attiverà la richiesta di inter¬ 
rupt su SPI, salterà alla locazione di memoria re¬ 
lativa al vettore e cioè 0F4H dove troverà l’istru¬ 
zione di salto jp CS_int, e attiverà così la routine 
descritta poco sopra. 

Nota: se avete già usato i programmi che fornia¬ 
mo come esempio dovreste già avere questo vet¬ 
tore corretto, in caso contrario all’indirizzo 0F4H in¬ 
serite l’istruzione jp CSJnt. 

Proseguendo troviamo: 

Idi ior,00010000b 

con questa istruzione abilitiamo tutti gli interrupt. 
Di seguito sono inserite: 


pippo 

Idi 

wdog,0ffh 


jrr 

3,port_c,res3 


jP 

pippo 

res3 

jrr 

0,port_a,rilpl 


jP 

pippo 

rilpl 

jrs 

0,port_a,sipll 


Idi 

wdog,0ffh 


jP 

rilpl 


Queste 8 istruzioni hanno il compito di testare se 
è stato premuto il pulsante PI e, nel caso, il rela¬ 
tivo rilascio evitando così rimbalzi e falsi segnali sul 
piedino 0 di Port_A. 

Inoltre si accede alla parte della gestione del pul¬ 
sante PI solamente quando il piedino 3 di Port_C 
è a livello logico 0 e cioè solo quando il dato è sta¬ 
to ricevuto e viene visualizzato tramite gli 8 leds 
(vedi routine CSJnt). 

sipll set 7,spmc 

Il programma salta a questa etichetta nel caso sia 
stato premuto correttamente il pulsante PI. 


In questo caso il bit 7 Sprun di spmv viene setta¬ 
to a 1 e ciò dà inizio alla ricezione dati. 

Il programma però non riceve ancora nulla, perché, 
come già detto, il micro Master è in condizione di 
Start di trasmissione e attende solamente un se¬ 
gnale sul suo piedino 2 di Port_C sotto forma di 
fronte di salita (rising edge) per iniziare ad inviare 
il clock e i dati. 

set 3,port_c 

Con questa istruzione inviamo finalmente questo 
segnale e a questo punto avrà inizio la trasmissio¬ 
ne del Master e la corrispondente ricezione. 

jp pippo 

Ora il programma ritorna al ciclo di gestione pul¬ 
sante PI per attivare eventualmente altri cicli di ri¬ 
cezione dati. 

COSTO di REALIZZAZIONE 

Tutti i componenti necessari per realizzare la sche¬ 
da LX.1380 visibile in fig.4 .€8,30 

Tutti i componenti necessari per realizzare la sche¬ 
da LX.1381 visibile in fig.7, compresi il quarzo, i 
diodi led, una piattina cablata completa di due con¬ 
nettori femmina Escluso il micro ST62/65 che po¬ 
trete richiedere a parte .€ 12,65 

Tutti i componenti necessari per realizzare la sche¬ 
da LX.1382 visibile in fig.11, compresi i tre display, 
gli 8 diodi led, 4 integrati 4049 più 8 zoccoli, 
una piattina cablata completa di due connettori fem¬ 
mina .€20,90 

Un dischetto floppy DF.1380 contenente i 5 pro¬ 
grammi descritti nel testo .€ 7,75 

Su richiesta possiamo fornire anche i micropro¬ 
cessori ST62/E65 riprogrammabili a .€ 18,08 

Costo del solo stampato LX.1380 .€ 4,29 

Costo del solo stampato LX.1381 .€ 3,41 

Costo del solo stampato LX.1382 .€ 5,68 

Nota: se ancora non avete la scheda bus siglata 
LX.1329, pubblicata sulla rivista N.192, ve la pos¬ 
siamo fornire completa di circuito stampato, zoc¬ 
coli, quarzo ed integrato 74HC00 a .€ 19,60 

Tutti prezzi sono già comprensivi di IVA. Coloro 
che richiedono il kit in contrassegno, dovranno ag¬ 
giungere le sole spese postali richieste dalle P.T. 
che si aggirano intorno a € 3,10 per pacco. 












COME PROGRAMMARE 


La SGS/Thomson ha cessato di produrre tutta la serie dei micro con le 
sigle ST62 e li ha sostituiti con la nuova serie ST6/C da programmare 
in ambiente Windows. Chi possiede il programmatore LX.1325 potrà u- 
sarlo anche per gli ST6/C, ma chi possiede solo il vecchio programma¬ 
tore LX.1170 dovrà completarlo con questa semplice interfaccia. 


Da tempo sapevamo che tutti i micro della serie 
ST62E10B - ST62E15B - ST62E20B ecc. seguiti 
dalle lettere SWD - HWD ed anche tutti gli OTP 
della serie ST62T10B-ST62T15B ST62T20B ecc., 
sarebbero stati messi fuori produzione e sostituiti 
con la nuova serie C, che, rispetto alle preceden¬ 
ti, ha in aggiunta l’option byte, che permette in fa¬ 
se di programmazione di settare diverse funzioni 
supplementari. 

Con questa nuova serie di micro, siglati ST62E10C 
oppure ST62T10C, ecc. (il numero è seguito dalla 
lettera C e non più da B o BB), è possibile ad e- 
sempio selezionare un watchdog tipo hardware o 
software, mentre con i precedenti micro si doveva 
necessariamente scegliere un chip con watchdog 
SWD (software) o con watchdog HWD (hardware). 
La SGS/Thomson ha realizzato il programma per 
programmare questa nuova versione C solo per 
ambiente Windows 3.1- 95 - 98. 


Chi utilizza per la programmazione dei computer 
che lavorano solo con il sistema operativo DOS, 
sprovvisti cioè di ambiente Windows, può ugual¬ 
mente programmare i nuovi micro ST6/C senza bi¬ 
sogno di realizzare l’interfaccia LX.1430, ma poi¬ 
ché con il DOS non si riesce a modificare l’option 
byte non potrà proteggerli, perché questa funzio¬ 
ne è presente solo nell’option byte. 

Importante 

Chi utilizza il nostro programmatore LX.1325 pre¬ 
sentato nella rivista N.192, dovrà solo caricare nel 
suo computer il programma che noi forniamo. 

Chi utilizza il precedente programmatore siglato 
LX.1170, apparso sulla rivista N.172, oltre a cari¬ 
care il programma dovrà necessariamente colle¬ 
gare l’interfaccia LX.1430 tra l’uscita del pro¬ 
grammatore e l’ingresso del computer. 








































































SCHEMA ELETTRICO INTERFACCIA 

Come potete vedere in fig.1 in questa interfaccia ab¬ 
biamo un solo integrato siglato 74HC04 provvisto di 
6 inverter, perché il programmatore LX.1170, per 
poter comunicare con il programma Epromer che vi 
forniamo, necessita di alcuni livelli logici invertiti. 

Nello schema elettrico il CONN.1 posto sulla sini¬ 
stra è il connettore maschio che andrà collegato 
all’uscita parallela del computer. 

Il CONN.2 posto sulla destra è invece il connetto¬ 
re femmina che andrà inserito nell’uscita del pro¬ 
grammatore LX.1170. 

In questo schema elettrico non abbiamo rispettato 
l’ordine sequenziale dei piedini dei connettori per 
non ritrovarci con un intreccio di fili difficile da di¬ 
stricare, ma abbiamo riportato i relativi numeri. 


In fig.6, dove abbiamo disegnato i due connettori 
maschio e femmina con vista frontale e posterio¬ 
re, potete vedere che questi connettori hanno 25 
piedini disposti su due file. 

La prima fila è di 13 piedini e la seconda, sotto¬ 
stante, di 12 piedini. 

Se il connettore femmina è visto frontalmente il 
piedino 1 si trova a destra, mentre nel connettore 

maschio si trova a sinistra. 

L’integrato va alimentato con una tensione di 5 volt, 
che preleviamo con i diodi DS1-DS2 dai piedini 14- 
16 del connettore maschio. 

REALIZZAZIONE PRATICA 

Per realizzare questa interfaccia abbiamo utiliz¬ 
zato il circuito stampato siglato LX.1430, che de¬ 
ve poi essere inserito all’interno del suo minu- 


nuovi MICRO serie ST6/C 


C0NN.1 C0NN.2 



< 

< 
OC 
C D 

o 

oc 

Q. 

O 

C/3 


CONNETTORE 25 POLI 

(MASCHIO) 


CONNETTORE 25 POLI 

(FEMMINA) 


ELENCO COMPONENTI 

RI = 10.000 ohm 

R2 = 10.000 ohm 

R3 = 10.000 ohm 

R4 = 10.000 ohm 

R5 = 10.000 ohm 

R6 = 10.000 ohm 

R7 = 1.000 ohm 

R8 = 1.000 ohm 

R9 = 1.000 ohm 

RIO = 1.000 ohm 

RII =22 ohm 

R12 = 1.000 ohm 

CI = 100.000 pF 

DS1 = diodo IN 4148 

DS2 = diodo IN 4148 

IC1 = integrato 74HC04 

CONN.1 = conn. maschio 

CONN.2 = conn. femmina 


Fig.1 Schema elettrico dell’interfaccia LX.1430. Tutte le resistenze sono da 1/8 di watt. 
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Fig.2 Connessioni del 74HC04 viste da 
sopra con la tacca a U rivolta a sinistra. 
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Fig.4 Schema pratico di montaggio del 
la piccola interfaccia. Il connettore ferri 



mina va inserito verso la RI 2. 
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FEMMINA 
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VERSO IL 
COMPUTER 


VERSO 
LX1170 


Fig.3 Foto dell’interfaccia già montata e, 
in basso, già racchiusa aM’interno del 
suo piccolo contenitore plastico. 


Fig.5 Tra le due file dei terminali dei con¬ 
nettori maschio e femmina dovete inne¬ 
stare il circuito stampato. 



MASCHIO 25 POLI 


1 


ooooooooooooo 
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Ho 


Fig.6 Guardando frontalmente il connettore Femmina, a sinistra è visibile il terminale 
13 e a destra il terminale 1. Guardando frontalmente il connettore Maschio, a sinistra 
è visibile il terminale 1 e a destra il terminale 13. 




























































scolo contenitore plastico (vedi fig.3). 

Potete iniziare il montaggio di questa scheda inse¬ 
rendo tutte le resistenze da 1/8 di watt, dopo aver 
ovviamente controllato il loro valore ohmico per non 
inserirle in una posizione errata. 

Dopo le resistenze potete montare i due diodi DS1- 
DS2 rivolgendo il lato contornato da una fascia ne¬ 
ra verso il condensatore CI , che potete inserire su¬ 
bito dopo nello stampato (vedi fig.4). 

Completato il montaggio di questi componenti mon¬ 
tate l’integrato IC1 che, contrariamente ad ogni no¬ 
stro montaggio, va innestato nello stampato senza 
zoccolo, diversamente non riuscirete a chiudere 
il mobile plastico. 

Prima di saldarne i piedini sul circuito stampato, 
controllate che la sua tacca di riferimento a forma 
di U sia rivolta verso il condensatore CI. 

A questo punto prendete il connettore maschio ed 
il connettore femmina e innestate il circuito stam¬ 
pato tra le due file dei loro terminali come visibile 
nelle figg.4-5, in modo che sopra ci sia la fila di 13 
terminali e sotto quella di 12 terminali, poi salda¬ 
te tutti i 25 terminali sulle piste del circuito stam¬ 
pato facendo attenzione a non cortocircuitare due 
piste adiacenti con un eccesso di stagno. 
Completate le saldature, potete inserire il circuito 
stampato dentro i due gusci del mobile plastico e 
chiuderlo. 

CARICARE il PROGRAMMA 

Per caricare il programma sul vostro hard-disk in¬ 
serite il disco siglato DFST6/C nel drive floppy. 

Se nel vostro computer è installato Windows 3.1 
dovete selezionare nella barra dei menu la scritta 
File; nella finestra che appare andate sulla riga E- 
segui ... e nella nuova finestra che appare dovete 
digitare A:setup poi cliccare su OK. 

Se nel vostro computer è installato Windows 95 
dovete cliccare con il cursore del mouse sulla scrit¬ 
ta Avvio, posta in basso a sinistra, e nella finestra 
che appare andate sulla riga Esegui ... quindi di¬ 
gitate A:setup e cliccate su OK. 

Se nel vostro computer è installato Windows 98 
dovete cliccare con il cursore del mouse sulla scrit¬ 
ta Start, posta in basso a sinistra, e nella finestra 
che appare andate sulla riga Esegui ... e digitate 
A:setup poi cliccate su OK. 

In questo modo lancerete l’installazione e verrà 
creato il gruppo di programmi contenente il file del 
programmatore. 



Fig.7 Dopo aver lanciato il file Epromer, sul 
monitor vi apparirà questa videata. 



Fig.8 Dopo aver cliccato sullo scritta Con' 
figure, cliccate su Configure Epromer. 



Fig.9 Quando apparirà questa finestra, se¬ 
lezionate la porta parallela e anche il tipo di 
programmatore (leggere testo). 



Fig.10 La mappa del micro risulterà vuota 
cioè con tutti 00, fino a quando non verrà 
richiamato un programma .Hex. 



















































Fig.11 Andando sulla scritta Read del me¬ 
nu, potete leggere il contenuto di un mi¬ 
croprocessore già programmato. 



Fig.12 Andando sulla scritta Program, po¬ 
tete trasferire un programma .Hex all’inter¬ 
no del microprocessore. 



Fig.13 Andando sulla scritta Verify, potete 
verificare se il micro che desiderate pro¬ 
grammare risulta vergine. 


Per far partire questo programma è sufficiente clic¬ 
care sul nome del programma Epromer. 

Nella nuova maschera che appare a video clicca- 
te sulla scritta Configure e poi su Configure 
Epromer (vedi figg.8-9). 

Quando sullo schermo appare la finestra visibile in 
fig.9 dovete selezionare la porta parallela che vo¬ 
lete utilizzare, cioè LPT1 o LPT2. 

Se il vostro computer ha la sola LPT1 e su questa 
è già collegata la stampante, dovete scollegarla 
ed inserire in sua sostituzione il connettore colle¬ 
gato al nostro programmatore. 

Come seconda operazione dovete selezionare nel¬ 
la finestra a sinistra il tipo di programmatore che 
userete. 

Se utilizzate il nostro programmatore LX.1325 do¬ 
vete selezionare la riga ST626X, perché con que¬ 
sto potete programmare tutti i microprocessori del¬ 
la serie ST6260 -ST6265, ecc. 

Se utilizzate il programmatore LX.1170, completo 
dell'Interfaccia LX.1430, dovete selezionare la riga 
ST622X, perché con questo potete programmare 
tutti i micro ST6210-ST6215, ecc. 

Dopo aver selezionato la porta parallela ed il tipo 
di programmatore, cliccate prima sul tasto con la 
scritta APPLY e poi sul tasto con la scritta OK ed 
in basso sullo schermo vedrete apparire il tipo di 
configurazione e la porta selezionata. 

Sul monitor apparirà la mappa della memoria rela¬ 
tiva al programma da caricare nel micro. 

Questa mappa, come visibile in fig.10, risulterà vuo¬ 
ta finché non verrà richiamato il programma .HEX. 
Come avrete modo di appurare, con questo nuo¬ 
vo programma oltre a programmare i nuovi ST6/C, 
riuscirete anche a programmare tutte le versioni 
dei micro precedenti. 

Infatti, cuccando sulla freccia a V posta sulla de¬ 
stra della sigla del micro (vedi fig.15), compariran¬ 
no a video tutte le sigle dei micro che è possibile 
programmare. 

Per selezionare uno dei tanti micro inclusi nella li¬ 
sta basta cliccare una volta sola sulla sigla del mi¬ 
cro desiderato. 

Nella riga in basso appariranno queste scritture: 

EPROM EEPROM Options Chip Information 

che potrete utilizzare per visualizzare a monitor le 
varie funzioni. 









































Fig.14 Andando sulla scritta Help, potete 
accedere ad una guida in linea, che risulta 
però scritta in inglese. 



Fig.15 Cliccando sulla freccia a V, posta a 
destra di ST62T00, vi apparirà la lista dei 
micro ST6 che potete programmare. 



Fig.16 Ammesso di aver scelto il micro 
ST62T1 OC, cliccando su Options appari¬ 
ranno tutte le funzioni dell’Option Byte. 


Eprom - visualizza il file con estensione .HEX da 


caricare sul micro. 

EEprom - visualizza l’area di memoria della EE- 
prom; questa funzione è attiva solo per quei micro 
che dispongono di tale memoria. 

Options - visualizza l’option byte che potrete set- 
tare secondo le vostre esigenze. 


Chip Information - visualizza alcune informazio¬ 


ni sul micro selezionato. 


OPTION BYTE per micro ST62XX 

Se cliccate su Options e selezionate ad esempio 
un micro ST62T10C (vedi fig.16), a video appari¬ 
ranno le seguenti righe, che vi permetteranno di 
settare o resettare le funzioni dell’option byte: 

[0] DO OSG enabled 

[0] DI Watchdog activation 

[0] D2 TIMER pin pull-up enabled 

[0] D3 NMI pin pull-up enabled 

[0] D6 Oscillator selection 

[0] D7 Read-Out Protection 

[0] D8 LVD Reset 

[0] D9 External STOP MODE Control 


OPTION BYTE per micro ST626X 

Se cliccate su Options e selezionate ad esempio 
un micro ST62T60 della serie C, a video appari¬ 
ranno le seguenti righe, che vi permetteranno di 
settare o resettare le funzioni dell’option byte. 

[0] DO OSG enabled 

[0] DI Oscill select 

[0] D2 POR delay 

[0] D3 Watchdog activation 

[0] D4 PB0-1 pins pull-up disabled 

[0] D5 PB2-3 pins pull-up disabled 

[0] D6 Extern STOP mode enabled 

[0] D7 Read-Out Protection 

[0] D8 HLVD enabled 

[0] D9 NMI pin pull-up enabled 

[0] DI 2 ADC Synchro 


Poiché non tutti sapranno già come usare queste 
nuove funzioni, vi diciamo subito che modificando 
il numero 0 racchiuso dentro le parentesi quadre 
con il numero 1 si ottiene quanto segue: 


OSG enabled - Tutti i micro della serie C dispon¬ 
gono internamente di uno stadio oscillatore di e- 
mergenza che permette al micro di funzionare con 
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Fig.17 Cuccando sulla scritta Chip Infor¬ 
mation, potete avere delle utili informazio¬ 
ni sul micro prescelto. 



Fig.18 Per programmare un microproces¬ 
sore ST62T60, dovete usare il programma¬ 
tore LX.1325 e selezionare ST626X. 



Fig.19 I micro da programmare possono es¬ 
sere selezionati anche cuccando sulla scrit¬ 
ta Select Chip di questa finestra. 


un clock interno ausiliario minore di 1 MHz, nel ca¬ 
so venisse a mancare il clock dello stadio oscilla¬ 
tore principale. Se lasciate [0] questa funzione ri¬ 
sulta disattivata, se invece mettete [1] questa fun¬ 
zione viene attivata. 


Oscillator selection - Lasciando [0] dovrete uti¬ 
lizzare per lo stadio oscillatore un quarzo; se in¬ 
vece mettete [1] potrete escludere il quarzo ed in¬ 
serire tra il piedino Osc.out e la massa una resi¬ 
stenza il cui valore determinerà la frequenza di 
clock. Con un valore di 470.000 ohm otterrete u- 
na frequenza di 1 MHz circa, con un valore di 
100.000 ohm otterrete una frequenza di 3 MHz cir¬ 
ca e con un valore di 47.000 ohm otterrete una fre¬ 
quenza di circa 5 MHz. La frequenza generata non 
risulterà però stabile come quella di un quarzo. 


POR delay- Lasciando [0] avrete un ritardo sull’e¬ 
secuzione della prima istruzione dopo che si è ve¬ 
rificato un reset di 2.048 cicli; se mettete [1] a- 
vrete un ritardo sull’esecuzione della prima istru¬ 
zione di ben 32.768 cicli. 


Watchdog activation - Lasciando [0] potrete atti¬ 
vare e disattivare il watchdog tramite istruzioni 
software; se mettete [1] il watchdog sarà di tipo 
hardware e non potrete disattivarlo tramite nessu¬ 
na istruzione software. 


PB0-1 - Lasciando [0] i pin PB0 e PB1 risultano 
collegati con una resistenza di pull-up al positivo di 
alimentazione; se mettete [1] viene esclusa su 
questi due piedini la resistenza che li collega al po¬ 
sitivo di alimentazione. 


PB2-3 - Lasciando [0] i pin PB2 e PB3 risultano 
collegati con una resistenza di pull-up al positivo di 
alimentazione; se mettete [1] viene esclusa su 
questi due piedini la resistenza che li collega al po¬ 
sitivo di alimentazione. 


TIMER pin pull-up - Se mettete [1] il pin del ti¬ 


mer viene collegato al positivo di alimentazione tra¬ 
mite una resistenza interna. 


NMI pin pull-up - Se mettete [1] il pin del NMI vie¬ 
ne collegato al positivo di alimentazione tramite u- 
na resistenza interna. 


External STOP - Se mettete [1] ed il pin NMI si 
trova a livello logico 1 , potrete eseguire la fun¬ 
zione di Stop anche con il watchdog hardware. 
In passato questa istruzione di Stop poteva esse¬ 
re eseguita solo con watchdog software. 


Read-Out Protection - Se mettete [1] protegge¬ 
rete il micro in lettura. 






















































































Fig.20 Dopo aver lanciato il programma, 
cliccate sulla scritta Configure e poi nuo¬ 
vamente su Configure Epromer. 



Fig.21 Ammesso di voler programmare un 
micro ST62E10C, come prima operazione 
andate sulla prima riga ST622X. 



Fig.22 Dopo aver cliccato sulla freccia a V, 
ricercate la sigla ST62E10C corrisponden¬ 
te al micro da programmare. 


LVD (HLVD) enabled - Lasciando [0] il reset vie¬ 
ne attivato solo portando a livello logico 0 il pin 
reset oppure all’accensione del micro. Se invece 
mettete ni la condizione di reset viene automati¬ 
camente attivata quando la tensione di alimenta¬ 
zione scende al disotto dei 3,7-3,5 volt, e disatti¬ 
vata automaticamente quando la tensione sale ol¬ 
tre i 4 volt. 


- Lasciando [0] la lettura dell’A/D 
non appena si comanda lo start 
convertion. Se mettete [1] potete posizionare il mi¬ 
cro sulla funzione Wait in modo da ridurre il “ru¬ 
more” durante la lettura A/D. Per ottenere questa 
lettura bisogna eseguire lo start conversion 
dell’A/D e poi si deve obbligatoriamente eseguire 
l’istruzione di Wait. 

Terminata la conversione, viene generata una ri¬ 
chiesta di interrupt dell’A/D che automaticamente 
permette l’uscita dalla condizione di Wait. 


ADC Synchro 

viene eseguita 


ESEMPIO di programmazione ST62E10C 

Supponiamo che abbiate un file già compilato, che 
potreste aver chiamato ad esempio Prova.Hex, e 
che lo abbiate memorizzato nella directory C:\ST6. 
Con questo programma desiderate programmare 
un micro ST62E10C utilizzando il nostro program¬ 
matore LX.1170 completo dell’interfaccia LX.1430. 

Come prima operazione dovete richiamare il pro¬ 
gramma Epromer e, se ancora non è stato confi¬ 
gurato, cliccate sul menu Configure e selezionate 
la riga ST622X, quindi cliccate sulla piccola fine¬ 
stra APPLY e di seguito su OK (vedi fig.21). 

Dopodiché cliccate sulla freccia a V posta sulla de¬ 
stra della sigla del micro (vedi fig.22) per far com¬ 
parire a video tutte le sigle dei micro. 

Ora andate sulla scritta ST62E10C e con un clic 
selezionate questo micro. 

Per caricare il programma andate sulla scritta Fi¬ 
le, posta in alto nella riga dei menu, e cliccando u- 
na sola volta col mouse apparirà una finestra e qui 
cliccate sulla scritta Open (vedi fig.23). 

Ora andate nella finestra C:\ e cercate la directory 
ST6 e qui cliccate 2 volte. 

Sulla finestra di sinistra appariranno tutti i file .HEX 
e nel nostro esempio selezionate la scritta Pro¬ 
va.Hex e poi cliccate su OK (vedi fig.25). 

In questo modo avrete caricato in memoria il file 
per programmare questo micro. 

Ora potete cliccare su Options per far apparire 































































le righe dell’option byte (vedi fig.27). 



Fig.23 Per caricare il programma in memo¬ 
ria, dovete cliccare sulla riga File posta in 
alto, poi sulla scritta Open. 



Fig.24 Dopo aver cliccato su Open, appa¬ 
rirà una finestra e qui ricercherete la direc¬ 
tory C:\ST6 che contiene il programma. 



Fig.25 Dopo aver selezionato la directory 
C:\ST6, nel riquadro di sinistra appariranno 
tutti i file con estensione .Hex. 


[0] DO OSG enabled 

[0] DI Watchdog activation 

[0] D2 TIMER pin pull-up enabled 

[0] D3 NMI pin pull-up enabled 

[0] D6 Oscillator selection 

[0] D7 Read-Out Protection 

[0] D8 LVD Reset 

[0] D9 External STOP MODE Control 

Se volete modificare l’opzione Watchdog, portate 
il cursore sullo [0] e cliccate 2 volte: in questo mo¬ 
do apparirà [1]. 

Se volete proteggere il micro in lettura dovete por¬ 
tare il cursore sullo [0] della riga Read-Out pro¬ 
tection e cliccare velocemente 2 volte in modo che 
appaia [1]. 

Ora tornate sulla riga Eprom posta in basso a si¬ 
nistra e cliccate su questa scritta per far apparire 
la finestra di fig.26. 

Per programmare il micro cliccate su Program poi 
sulla finestra All. 

Le scritte poste nella parte alta di questa finestra so¬ 
no già molto intuitive, comunque vi diciamo che an¬ 
dando su READ potrete leggere il contenuto del mi¬ 
cro a patto che questo non risulti protetto in lettura. 

Andando sulla scritta VERIFY e poi su Blanck 
Check potrete verificare se il micro risulta ancora 
vergine o contiene già un programma. Questa fun¬ 
zione potrebbe risultare utile per verificare se la 
lampada ultravioletta l’ha totalmente cancellato. 

ESEMPIO di programmazione ST62E60C 

Supponiamo che abbiate un file già compilato, che 
potreste aver chiamato ad esempio Prova.Hex, e 
di averlo memorizzato nella directory C:\ST626. 
Con questo programma desiderate programmare 
un micro ST62E60C utilizzando il nostro program¬ 
matore LX.1325. 

Come prima operazione dovete richiamare il pro¬ 
gramma Epromer e se ancora non è stato confi¬ 
gurato, andate sul menu e cliccate su Configure e 
selezionate la riga ST626X, quindi cliccate sulla 
piccola finestra APPLY e di seguito su OK. 

Dopodiché cliccate sulla freccia a V posta sulla de¬ 
stra della sigla del micro (vedi fig.22) per far com¬ 
parire a video tutte le sigle dei micro. 

Ora andate sulla riga ST62E60C e con un clic se¬ 
lezionate questo micro. 


















































































Per caricare il programma andate sulla scritta Fi¬ 
le, posta in alto nella riga dei menu, e cliccando u- 
na sola volta col mouse apparirà una finestra (ve¬ 
di fig.23) dove cliccherete sulla scritta Open. 

Ora andate nella finestra C:\ e cercate la directory 
ST626 per cliccarci sopra 2 volte. 

Sulla finestra di sinistra appariranno tutti i file .HEX 
e nel nostro esempio selezionate la scritta Pro- 
va.Hex e poi cliccate su OK. 

In questo modo avrete caricato in memoria il file 
per programmare questo micro. 

Ora potete cliccare su Options per far apparire le 
righe deH’option byte. 

[0] DO OSG enabled 

[0] DI Oscill select 

[0] D2 POR delay 

[0] D3 Watchdog activation 

[0] D4 PB0-1 pins pull-up disabled 

[0] D5 PB2-3 pins pull-up disabled 

[0] D6 Extern STOP mode enabled 

[0] D7 Read-Out Protection 

[0] D8 HLVD enabled 

[0] D9 NMI pin pull-up enabled 

[0] DI 2 ADC Synchro 

Se volete proteggere il micro in lettura, dovete por¬ 
tare il cursore sullo [0] della riga Read-Out pro¬ 
tection e cliccare velocemente 2 volte in modo che 
appaia [1]. 

Con questo micro potete visualizzare il contenuto 
della EEprom cliccando in basso sulla riga EE- 
prom. Nella schermata che appare potete modifi¬ 
care manualmente il contenuto di questa area di 
memoria. 

Ora ritornate sulla riga Eprom posta in basso a si¬ 
nistra e cliccate su questa scritta per far apparire 
la finestra di fig.26. 

Per programmare il micro cliccate su Program poi 
sulla finestra All. 

COSTO di REALIZZAZIONE 

Tutti i componenti necessari per realizzare questa 
interfaccia LX.1430 (vedi fig.4), compresi due con¬ 
nettori e un piccolo mobile plastico .€5,40 

Costo del circuito stampato LX.1430 .€1,03 

Programma DFST6/C sotto Windows .€7,75 

Nota = Questa interfaccia serve solo per usare il 
programmatore LX.1170 sotto Windows. 

Il programmatore LX.1325 non ha bisogno di que¬ 
sta interfaccia, ma solo del programma DFST6/C. 



































COME UT L ZZARE 


Molti consigliano di usare nei programmi per gli ST6 le direttive del lin¬ 
guaggio Assembler, ma pochi spiegano come si fa. E’ inutile consiglia¬ 
re di trasformare le istruzioni in una “macro”, se non si spiegano quali 
accorgimenti adottare per evitare errori. In questo articolo vi spieghia¬ 
mo ciò che occorre sapere per usare correttamente la direttiva .macro. 


Se non programmate i micro ST6, questo articolo 
sarà per voi poco interessante, ma per le piccole 
Industrie che utilizzano questo microprocessore 
non è così, tant’è vero che insistono affinché ven¬ 
gano dedicate più pagine sulla rivista a questo ar¬ 
gomento, perché quello che noi spieghiamo non si 
trova in nessun manuale. 

Oggi li accontenteremo spiegando come si possa 
trasformare un gruppo di istruzioni in una macro. 

Nella stesura di un programma capita di frequen¬ 
te di dover utilizzare delle sequenze di istruzioni 
che sono già state scritte per programmi prece¬ 
denti, come ad esempio quelle per eseguire delle 
somme, per configurare le porte, per visualizza¬ 
re dei dati sul display ecc. 

In questi casi capita spesso che le istruzioni ven¬ 
gano riscritte con il rischio di inserire degli errori. 

Chi ha un po’ di esperienza si avvale di un altro 
metodo, va cioè alla ricerca dei programmi in cui 
sa che ci siano queste istruzioni, poi, adoperando 


le funzioni dell’editor normalmente usate nella vi¬ 
deoscrittura, seleziona quelle di cui ha bisogno e 
le incolla direttamente nel nuovo programma, ap¬ 
portando eventuali modifiche per renderle compa¬ 
tibili alle nuove esigenze. 

Questa soluzione è sicuramente molto valida, ma 
può presentare piccoli inconvenienti. 

Se dopo avere incollato le istruzioni nel nuovo pro¬ 
gramma ci si accorge che c’è un errore oppure si 
scopre che è possibile perfezionarle, come ricor¬ 
dare in quali altri programmi sono state utilizzate 
per poterle correggere? 

Ebbene, non tutti sanno che c’è un’altra soluzione, 
sicuramente molto valida, che consiste nel sele¬ 
zionare tutti i blocchi di istruzioni che possono ser¬ 
vire in altri programmi, per memorizzarli in una i- 
struzione macro a cui verrà assegnato un nome. 

Procedendo in questo modo, ogni volta che si scri¬ 
verà un nuovo programma e serviranno queste i- 




































































struzioni, non si dovrà più perdere tempo per an¬ 
darle a cercare, ma sarà sufficiente inserire nel 
punto desiderato il nome della macro che le con¬ 
tiene ed assemblare il programma. 

Questa soluzione offre molti vantaggi ai program¬ 
matori, perché se ci si accorge che nelle istruzioni 
è presente un errore oppure che è possibile mi¬ 
gliorarle, basta correggere la sola macro per a- 
vere la certezza che in tutti i programmi in cui è 
stata utilizzata o che verrà utilizzata sarà perfetta. 

Per rendere ancora più agevole l’uso di queste ma¬ 
cro non va dimenticato di assegnare dei nomi che 
siano il più possibile significativi, così da poter ca¬ 
pire immediatamente quali funzioni eseguono. 

Di conseguenza se avete una macro che esegue 
delle somme, datele il nome sommat, se avete u- 
na macro che configura le porte, datele il nome 
defport e così via. 


corrispondenza dell’etichetta Iamp4 e sono: 


Iamp4 



Idi 

wdog,0feh 


jrr 

4,port_b,lamp0 


res 

4,port_b 


jP 

lampi 

lampo 

set 

4,port_b 

lampi 

cali 

delay 


jP 

Iamp4 


Per creare una macro da adoperare in altri pro¬ 
grammi dobbiamo innanzitutto scegliere un nome 
che ci ricordi quale funzione svolge questo gruppo 
di istruzioni e poiché fanno lampeggiare un diodo 
led potremmo chiamare la macro: 

ledflash 

Ricordatevi sempre che i nomi non possono mai 
superare gli 8 caratteri. 


la DIRETTIVA .MACRO 


Inoltre vi consigliamo di inserire sempre un com¬ 
mento che spieghi quale funzione esegue la ma¬ 
cro, perché col tempo è facile dimenticarsene. 

Un altro consiglio che vi diamo è quello di creare 
una directory, che potrete ad esempio chiamare 
dirmacro, nella quale memorizzare tutte le vostre 
macro, in modo da avere una libreria sempre ag¬ 
giornata e facile da consultare. 

Il modo più semplice per imparare a creare e a u- 
tilizzare una macro è sicuramente quello di affi¬ 
darsi alla pratica, pertanto di seguito troverete al¬ 
cuni esempi per trasformare una sequenza di i- 
struzioni in una macro. 


COME creare una MACRO 


Supponiamo di avere un semplice programma 
chiamato LAMPLED.ASM, che provvede a far lam¬ 
peggiare un diodo led collegato sul pin 4 di Por¬ 
ta B di un ST6210. 

Nella fig.1, riportata nella pagina seguente, potete 
vedere il listato completo di questo programma. 

Le istruzioni per il lampeggio sono state poste in 


Per trasformare queste istruzioni in una macro oc¬ 
corre utilizzare due sole direttive: 

.macro e .endm 

che vanno scritte secondo questo formato: 

.macro nome [,variab] [,\num] [,?label] 
.endm 

Nel nostro caso la direttiva .macro va inserita nel¬ 
la riga precedente al gruppo di istruzioni che vo¬ 
gliamo trasformare in una macro e la .endm nella 
riga successiva al gruppo di istruzioni. 

Dopo la direttiva .macro scriviamo il nome scelto, 
cioè ledflash, e nelle voci tra parentesi quadre [ ] 
racchiuderemo i tre parametri opzionali che potre¬ 
mo inserire prima della compilazione per rendere 
la macro parametrizzabile. 

Con il programma di editor che utilizziamo nor¬ 
malmente per scrivere i programmi apriamo un 
nuovo documento e iniziamo a scrivere: 

.macro ledflash 

Come vedete la prima istruzione è la direttiva .ma- 





PROGRAMMA per far LAMPEGGIARE un LED sul PIN 4 di PORTA B 


.title "LAMPLED" ;1 titolo del programma 

.vers "ST62E10" ;2 tipo di microprocessore 


.romsize 2 

;+-+ 

;| VARIABILI DEL MICRO I 

;+-+ 


; Attenzione: Le righe da 3 a 24 non vanno mai modificate 


a 

. de f 

Of fh 

;3 

ac cumul at o r e 

X 

. de f 

OSOh 

;4 

registro x 

y 

. de f 

OS Ih 

;S 

registro y 

V 

. de f 

0S2h 

;6 

registro v 

T.T 

. de f 

0S3h 

;7 

registro w 

port_a 

. de f 

Oc Oh 

;S 

porta A 

port_b 

. de f 

Oc Ih 

;9 

porta B 

port c 

. de f 

0c2h 

;io 

porta C 

pdir_a 

. de f 

0c4h 

;ii 

direzione porta A 

pdir_b 

. de f 

OcSh 

;1Z 

direzione porta B 

pdir c 

. de f 

0c6h 

;13 

direzione porta C 

popt a 

. de f 

Oc eh 

;14 

opzioni porta A 

popt_b 

. de f 

Ocdh 

;1E 

opzioni porta B 

popt c 

. de f 

Oc eh 

;is 

opzioni porta C 

ior 

. de f 

OcSh 

;17 

registro interrupt 

addr 

. de f 

OdOh 

;is 

dato convertitore A/D 

adcr 

. de f 

Odlh 

;19 

registro convertitore A/D 

psc 

. de f 

0d2h 

;Z0 

registro del timer 

ter 

. de f 

0d3h 

;Z1 

contatore del timer 

tscr 

. de f 

0d4h 

;ZZ 

registro presealler del timer 

■wdog 

. de f 

OdSh 

;Z3 

registro del uatchdog 

drT.T 

. de f 

OcSh 

;Z4 

registro data rom uindou 


;*** Settaggio iniziale * 

.org OSSOh 


inizio 

Idi wdog^Offh 

-*** setta la porta B 

Idi port_b„0001000Oh 

Idi p dir_b,0001000Oh 

Idi popt_b,0001000Ob 


BUE per ST62E10 ST62E15 
;26 etichetta inizio 
;27 ricarica il uatch dog 


36 

bit 

0 

= 

non 

usato 

37 

bit 

1 

= 

non 

usato 

3S 

bit 

2 

= 

non 

usato 

39 

bit 

3 

= 

non 

usato 

40 

bit 

4 

= 

uscita per led 1 

41 

bit 

5 

= 

non 

usato 

42 

bit 

6 

= 

non 

usato 

43 

bit 

7 

= 

non 

usato 


Idi 

adc r,0000000Ob 

;4S 

Idi 

tscr^OOOOOOOOb 

;49 

Idi 

ior, 0000000Ob 

; 50 

reti 


;5l 

jP 

main 

;52 


disabilita il convertitore A/D 
disabilita il TIMER 
disabilita tutti gli interrupt 
istruzione da non togliere 
salta al programma principale 


;H0TA Se usiamo un ST62E20 o un ST62E25 nella riga 25 occorre mettere OSOh 













*** Gestori di interrupt *** 

*****************************************************■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■*■*■■*■■*■■*■■*■■*■■*■■*■■*■ 

; In questo programma non vengono usati gli interrupt ma bisogna ugualmente 
; inserire queste righe 


ad int 

reti 


;£ 3 

interrupt del convertitore À/D 

tim int 

reti 


;S4 

interrupt del timer 

BC_int 

reti 


;££ 

interrupt delle porte B e C 

A_int 

reti 


;£6 

interrupt della porta A 

nmi_int 

reti 


;S7 

interrupt del piedino NMI 

-■*■■+■■+■■+■■+■ ■+■ 

■*■■*■ ■*■■*■■*■■*■■*■ * 

■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■* 


- * * * 



SUB ROUTINE 

* * * 

- ****** 




delay 

Idi 

wdog,0 feh 

;£8 



Idi 

y,20 

;S9 


de lai 

Idi 

wdog,0 feh 

; 60 



Idi 

x,20 

;6i 


delaZ 

dee 

X 

;62 



j rnz 

delaZ 

; 63 



dee 

y 

;64 



j rnz 

de lai 

; 6£ 



ret 


; 66 


- ■*■ * * * * * 
f 

* ■*■■*■■*■ *** * 

***************************** 

■■fr******************************** 

f 



PROGRAMMA PRINCIPALE *** 

- * *■*■■*■ * * 

■*■■*■■*■■*■■*■*■*■■*■ 

■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■*■■* 


main 

Idi 

wdog,0 feh 

;67 

ricarica il uatch dog 


res 

4,port_b 

; 68 

diseccita il led 1 (LI) 

lamp4 



;69 

etichetta per la ripetizione 


Idi 

wdog,0 feh 

;70 

ricarica il uatch dog 


j rr 

4,port b,. 

L amp 0 ; 71 

se spento vai a lampO 


res 

4,port b 

;72 

altrimenti lo spengo 


jP 

lampi 

; 73 


lampO 

set 

4,port_b 

;74 

se spento lo accendo 

lampi 

cali 

delay 

; 7£ 

ritardo 


jP 

lamp4 

; 76 

ritorna 




VETTORI DI INTERROTTE 


-*************************************************************************** 1 * 1 


ione : 

Le righe da 93 

a 109 non vanno 

mai modif: 

icate 

. org 

Of fOh 

; 93 



jP 

ad int 

; 99 

interrupt 

del convertiti 

jP 

t im_int 

; 100 

interrupt 

del timer 

jP 

BC_int 

; 101 

interrupt 

porte B e C 

jP 

A_int 

; 102 

interrupt 

porta A 

. org 

Of fch 

; 103 



jP 

rim i_ int 

; 104 

interrupt 

piedino nmi 

jP 

inizio 

; 10£ 

salta a inizio al reset 

. end 


; 109 

fine del programma 


Fig.1 II listato completo del programma sorgente che provvede a far lampeggiare un dio¬ 
do led collegato sul piedino 4 di porta B di un ST62E10. Compilando questo programma 
otterrete un programma in formato intei eseguibile con estensione .HEX. 








ero seguita dal nome ledflash, con il quale d’ora 
in poi dovrà essere richiamata questa macro all’in- 
terno di un programma. 

Tralasciamo per ora i parametri racchiusi tra [ ] per¬ 
ché li spiegheremo con gli esempi successivi. 

Prima della direttiva .macro non va inserita alcuna 
etichetta perché il compilatore la ignorerebbe. 

A questo punto inseriamo i comandi che vogliamo 
raggruppare in una macro. 


lampo 

lampi 


jrr 

res 

jP 

set 

.endm 


4,port_b,lamp0 

4,port_b 

lampi 

4,port_b 


Come avrete notato nella riga successiva alla eti¬ 
chetta lampi abbiamo inserito la direttiva .endm, 
per segnalare al compilatore la fine delle istruzioni 
della macro ledflash. 

La direttiva .endm va tassativamente inserita co¬ 
me ultima istruzione di qualsiasi macro. 

Anche in questo caso davanti alla direttiva .endm 
non scrivete alcuna etichetta, perché il compilato¬ 
re la ignorerebbe. 

Ora che la macro è stata creata dobbiamo salvar¬ 
la in un file che chiameremo LEDFLASH.LMA. 

L’estensione .LMA sta per Libreria Macro Assem¬ 
bler e serve a ricordarci che questo file è una ma¬ 
cro e non un programma completo. 

Ovviamente potrete chiamarla con il nome che ri¬ 
tenete più opportuno e scegliere l’estensione che 
ritenete più valida, ma non usate mai le estensio¬ 
ni tipo .EXE, .HEX, .GIF, .HTM o .INI ecc. perché 
sono riservate e potrebbero dar luogo a problemi. 

Potrete anche lasciare l’estensione .ASM e salva¬ 
re il file in un’altra directory chiamata MACRO. 

Creata una macro, possiamo inserirla nel pro¬ 
gramma lampled scrivendo semplicemente queste 
istruzioni: 


Come vedete, rispetto al listato di fig.1 abbiamo so¬ 
stituito le istruzioni che eseguivano il lampeggio con 
la sola parola ledflash. 

Se ora proviamo a ricompilare il programma LAM- 
PLED.ASM, avremo però la sgradita sorpresa del¬ 
la segnalazione di questo errore: 

Error LAMPLED.ASM 

(67) undefined macro : ledflash 

Eppure noi abbiamo creato correttamente la macro 
ledflash dentro al file LEDFLASH.LMA. 

Il compilatore quando arriva alla parola ledflash 
non la riconosce come istruzione assembler e cer¬ 
ca di interpretarla come macro, ma non la trova 
ancora esattamente definita. 

Per definirla esattamente dobbiamo inserire nel 
programma LAMPLED.ASM anche l’istruzione: 


.input 


‘ledflash.LMA” 


Sebbene non ci sia un punto preciso nel quale scri¬ 
vere questa istruzione, noi consigliamo di inserirla 
dove c’è la dichiarazione della configurazione del¬ 
le porte così da essere immediatamente notata. 

Conoscete la direttiva .input (vedi rivista N.182) e 
perciò sapete che quando il compilatore la incon¬ 
tra inserisce nel programma che sta compilando 
tutto ciò che trova memorizzato nel file segnalato 
tra virgolette “ ”. 

Nel nostro caso il compilatore cerca il file genera¬ 
to in precedenza e chiamato ledflash.LMA e in¬ 
serisce nel programma LAMPLED.ASM tutte le i- 
struzioni lì contenute. 

Nel nostro esempio verranno quindi inserite: 


.macro 

ledflash 

jrr 

4,port_b,lamp0 

res 

4,port_b 

ÌP 

lampi 

set 

4,port_b 

.endm 



lampo 

lampi 


A questo punto, nel ricompilare il programma, 
quando il compilatore arriverà all’istruzione: 


Iamp4 


Idi 

ledflash 

cali 

jP 


wdog,0feh 

delay 

Iamp4 


Iamp4 


Idi 

ledflash 

cali 

ÌP 


wdog,0feh 

delay 

Iamp4 


capirà che ledflash è una macro e la sostituirà con 
le istruzioni prelevate da LEDFLASH.LMA. 

Il sorgente LAMPLED.ASM continuerà ad essere 
scritto come segue: 

Iamp4 

Idi wdog,0feh 

ledflash 

cali delay 

jp Iamp4 

mentre il file LAMPLED.HEX conterrà in formato 
eseguibile le seguenti istruzioni: 


Iamp4 



Idi 


wdog,0feh 


jrr 


4,port_b,lamp0 


res 


4,port_b 


jP 


lampi 

lampo 

set 


4,port_b 

lampi 

cali 


delay 


jP 


Iamp4 


Ind. Codice 

Label 

Mnemonico 

089D 0DD8FE 

delay 

Idi 

ttdog,FEh 

08A0 0D8114 


Idi 

y, 14h 

08A3 0D8014 

delal 

Idi 

x, 14h 

08A6 1D 

dela2 

dee 

X 

Q8A7 FO 


jrnz 

dela2 

G8A8 5D 


dee 

V 

03A9 C3 


jrnz 

delal 

OSAA CD 


ret 


OSAB 0DD3FE 

min 

Idi 

udog,FEh 

OSAE 2 BC1 


res 

4,port b 

■> 03B0 0DD3FE 

lamp4 

Idi 

udog,FEh 1 

03B3 2 3 C104 


jrr 

4 f port b,lampO 

03B 6 2 BC1 


res 

4 f port b 

03B3 C93B 


JP 

lampi 

03BA 3 BC1 

lampO 

set 

4 f port b 

03BC D139 

lampi 

cali 

delay 

03BE 093B 


jP 

lamp4 

OSCO FFFF 


dee 

a 

Fig.2 Nella 

simulazione 

del programma 

LAMPLED.HEX, Tistruzione ledflash è stata 

sostituita con le istruzioni della macro. 


A riprova di quanto detto, abbiamo simulato il pro¬ 
gramma in esecuzione col simulatore ST626 e in 
fig.2 è visibile la parte in cui avevamo inizialmente 
sostituito le istruzioni di lampeggio con il comando 
ledflash. Come potete notare, non esiste più led¬ 
flash, perché al suo posto il compilatore ha inseri¬ 
to le istruzioni della macro. 

Abbiamo poi compilato LAMPLED.ASM con l’op¬ 
zione -L ottenendo così anche il listato del pro¬ 
gramma (LAMPLED.LIS) e in fig.3 è visibile il pun¬ 
to in cui è stata inserita la direttiva: 

.input “LEDFLASH.LMA” 

Nota: nella rivista N.194 vi abbiamo insegnato co¬ 
me leggere i listati .LIS. 

Come potete notare, subito dopo questa direttiva è 
stata inserita la sequenza di istruzioni contenuta 
nel file LEDFLASH.LMA, che non occupa nessu¬ 
na area di memoria, come visibile nella parte sini¬ 
stra del tabulato sotto la dicitura: 

-SOURCE FILE : LEDFLASH.LMA- 

In fig.4 è invece visibile il punto del listato in cui a- 
vevamo inserito la macro ledflash. 

Sottolineiamo ancora una volta che il compilatore 
ha sostituito la macro con le relative istruzioni e 
anche se nella riga 109 il nome ledflash è rima¬ 
sto, non occupa nessuna area di memoria come 
visibile alla sua sinistra. 


LE SPECIFICHE della DIRETTIVA .MACRO 


È abbastanza intuitivo che la macro ledflash così 
com’è può essere richiamata solo nei programmi 
che utilizzano il pin 4 di porta B. 

Se volessimo utilizzare un qualsiasi piedino di u- 
na qualsiasi porta dovremmo necessariamente 


37 


37 


. input- 

"LEDFLASH.LHA" 

- SOURCE FILE : 

: LEDFLASH.LMA - 





38 

1 

1 


.macro 

ledflash 

39 

1 

2 


j rr 

4,.port b f lampO 

40 

1 

3 


ras 

4,port b 

41 

1 

4 


jP 

lampi 

42 

1 

5 

lampO 



43 

1 

6 


set 

4,port b 

44 

1 

7 

lampi 



45 

1 

3 


. endm 



Fig.3 Parte del listato LAMPLED.LIS generato con l’opzione -L in cui è stata inserita la di¬ 
rettiva .input. Come potete notare, dopo questa direttiva il compilatore inserisce nel pro¬ 
gramma ciò che trova nel file segnalato tra virgolette, cioè nel file “ledflash.Ima”. 

















104 

P00 

03 AB 


P00 

OS AB 


96 

main 



10S 

P00 

03 AB 

ODDSFE 

P00 

03 AB 


97 


Idi 

wdog,0feh 

106 

P00 

OSAE 

2BC1 

P00 

OSAE 


93 


ras 

4,.port b 

107 

P00 

OSSO 


P00 

OSSO 


99 

lamp4 



108 

P00 

03B0 

ODDSFE 

P00 

OSSO 


100 


Idi 

mdog-, 0 f eh 

109 







101 


ledflash 

110 

P00 

03B3 

23C104 

P00 

03B3 

1 

2 


j rr 

4,p ort_b,1amp 0 

111 

P00 

OSE 6 

2BC1 

P00 

OSE 6 

1 

3 


res 

4,port_b 

112 

P00 

03B 3 

C93B 

P00 

03B 3 

1 

4 


jP 

lampi 

113 

P00 

03BA 


P00 

03BA 

1 

E 

lampO 



114 

P00 

03BA 

3BC1 

P00 

03BA 

1 

6 


set 

4,.port b 

HE 

P00 

OSBC 


P00 

OSBC 

1 

7 

lampi 



116 






1 

3 


. endm 


117 

P00 

03BC 

D1S9 

P00 

OSBC 


102 


cali 

delay 

113 

P00 

03BE 

093B 

P00 

03BE 


103 


jP 

lamp4 

119 







104 





Fig.4 Parte del listato LAMPLED.LIS generato con l’opzione -L in cui sono state inserite 
le istruzioni contenute nella macro ledflash (vedi da riga 109 a riga 116). Vi facciamo no¬ 
tare che sebbene il nome ledflash sia ancora presente, non occupa nessuna area di me¬ 
moria: infatti, a destra del numero 109 non c’è nessuna scritta. 


creare una nuova macro modificando i soli para¬ 
metri racchiusi tra parentesi quadre [ ]. 

Infatti, quando si dichiara una .macro, oltre al no¬ 
me possiamo definire tre differenti categorie di pa¬ 
rametri che in fase di compilazione verranno “pas¬ 
sate” e sostituite alle istruzioni inserite nella macro 
stessa rendendola più duttile. 

In questo modo potremo modificare la stessa ma¬ 
cro a seconda delle necessità e delle circostanze. 

Queste tre categorie rappresentano la cosiddetta 
COMMON AREA o area di Link della macro. 

Cerchiamo di spiegarci meglio procedendo ancora 
una volta con degli esempi pratici. 


Il parametro [,variab] 


Se analizziamo il file LEDFLASH.LMA vediamo 
che le istruzioni inserite sono costituite essenzial¬ 
mente da 4 gruppi, cioè: 

- le istruzioni Assembler vere e proprie: 

jrr res jp set 

- le variabili: 

port_b 

- le costanti numeriche: 

4 

- le labels o etichette interne: 

lampo lampi 


Con il parametro [,variab] possiamo rendere pa¬ 
rametrica la variabile port_b, riuscendo ad ottene¬ 
re una macro che esegue il lampeggio sempre sul 
pin 4, ma di una qualsiasi porta del micro, se pas¬ 
siamo questa informazione dal programma princi¬ 
pale alla macro. 

Riprendiamo perciò il nostro file LEDFLASH.LMA 
e modifichiamolo in questo modo: 


.macro 

ledflash cheporta 

jrr 

4,cheporta,lampo 

res 

4,cheporta 

jp 

lampi 

set 

4,cheporta 

.endm 



In altre parole dopo ledflash abbiamo inserito uno 
spazio seguito dalla parola cheporta, poi abbiamo 
sostituito tutte le istruzioni che usano port_b sem¬ 
pre con la scritta cheporta. 

In questo modo abbiamo inserito nella macro il pa¬ 
rametro [,variab]. 

Nota: in questo caso, essendo cheporta il primo 
parametro della macro non si deve inserire alcuna 
virgola dopo ledflash. 

Noi abbiamo utilizzato il termine cheporta, ma po¬ 
tevamo usare qualsiasi altro nome, ad esempio 
pippo, finestra ecc., anche se è consigliabile u- 





sare sempre delle parole che identifichino il tipo di 
variabile da modificare in modo inequivocabile. 

Ora modifichiamo il programma LAMPLED.ASM 
scrivendo nella riga della macro: 

ledflash port_ 

In coda a ledflash abbiamo dunque inserito la va¬ 
riabile port_b. 

Assemblando il programma LAMPLED.ASM, 
quando il compilatore troverà ledflash port_b, la 
sostituirà con le istruzioni di ledflash.LMA sosti¬ 
tuendo il parametro cheporta con port_b. 

Se anziché scrivere: 

ledflash port b 

avessimo scritto: 

ledflash port_c 

il compilatore avrebbe caricato al suo posto le i- 
struzioni di ledflash.LMA sostituendo il parametro 

cheporta con port_c. 

In questo modo abbiamo usato la COMMON AREA 
della macro per passare un parametro variabile, 
ottenendo così una macro che può funzionare in¬ 
differentemente su tutte le porte del micro. 

Se nel programma LAMPLED.ASM avessimo scrit¬ 
to solamente: 

ledflash 

dimenticandoci di completarla con port_b, il com¬ 
pilatore si sarebbe trovato nell’impossibilità di so¬ 
stituire cheporta ed avrebbe segnalato l’errore che 
abbiamo riportato in fig.5, pertanto quando si uti¬ 
lizzano i parametri della direttiva .macro bisogna 
fare molta attenzione. 


Il parametro [,\num] 


Pur avendo reso parametrica la porta, il lampeg¬ 
gio avverrà sempre sul pin 4 della porta prescelta, 
quindi per scegliere un diverso pin, dovremo va¬ 
riare nella macro il numero 4. 

Per scegliere un pin diverso si utilizza il parame¬ 
tro [,\num] modificando il file LEDFLASH.LMA nel 
modo seguente: 


.macro 

ledflash cheporta, \chepin 

jrr 

chepin,cheporta,lampo 

res 

chepin,cheporta 

ÌP 

lampi 

set 

chepin,cheporta 

.endm 



Come avrete notato, dopo cheporta abbiamo in¬ 
serito una virgola, una barra rovesciata ed il pa¬ 
rametro chepln sostituendolo al numero 4 presen¬ 
te nelle istruzioni. 

Importante: la barra rovesciata prima di chepin 
va inserita solo nella riga della direttiva .macro per 
indicare che qui verrà inserito un nuovo valore nu¬ 
merico [,\num]. Le istruzioni in cui abbiamo inseri¬ 
to chepin richiedono infatti, in quella posizione, un 
numero e non il contenuto di una variabile. 

In questo caso abbiamo usato il nome chepin, ma 
potevamo chiamarlo con il nome pinout ecc. 

Ora dobbiamo modificare nel programma LAM¬ 
PLED.ASM la macro ledflash come segue: 

ledflash port_b,4 

Quando il Compilatore assembler troverà ledflash 
port_b,4 caricherà al suo posto le istruzioni di LED- 
FLASH.LMA sostituendo il parametro cheporta 
con port_b ed il parametro chepin con 4. 
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Error LEDFLASH.LMA 2: (-1) syntax error 

Error LEDFLASH.LMA 2: (110) data addresses must be in thè range [Q..0ffh] 
Execution time: 1 second(s) 

2 errors detected 
No object created 

Fig.5 Questo errore è stato generato perché nel file LEDFLASH.LMA è stata parametriz- 
zata una variabile, che però non è stata definita nel programma in formato .ASM. A cau¬ 
sa di ciò il compilatore non ha potuto generare il file in formato .HEX. 





Error LEDFLASH.LMtì 2: (2G) operane! expected: 3-bit 
Uarning LEDFLASH.LMtì 2: (91) 2> r/w access control 
Error LEDFLASH.LMtì 3: (2Q) operand expected: 3-bit 
Uarning LEDFLASH.LMtì 3: (91) 2> r/w access control 
Error LEDFLASH.LMtì 5: (2Q) operand expected: 3-bit 
Uarning LEDFLASH.LMtì 5: (91) 2> r/w access control 
Execution time: G second(s) 

3 errors detected 
3 warnings 
No object created 


number 

not done on 

number 

not done on 

number 

not done on 


data-space 

data-space 

data-space 


operand 

operand 

operand 


Fig.6 In questo caso l’errore è stato generato perché pur avendo definito nel file in for¬ 
mato .ASM i parametri da associare alla macro ledflash, la variabile port_b e la costante 
numerica 4 sono state invertite. L’uso dei parametri opzionali rende la macro più duttile 
e perciò adattabile alle diverse necessità e circostanze, ma è necessario fare molta at¬ 
tenzione quando si definiscono questi parametri nei programmi sorgente. 


Se invece avessimo scritto: 

ledflash port_b,6 

quando il compilatore avrebbe assemblato il pro¬ 
gramma avrebbe sostituito i parametri cheporta e 
chepin presenti in LEDFLASH.LMA con port_b e 
con 6. Il lampeggio in questo ultimo caso sareb¬ 
be avvenuto sul pin 6 della porta B e non più sul 
pin 4 della porta B. 

Come avrete capito bastano poche modifiche per 
far lampeggiare il diodo led posto su un qualsiasi 
piedino delle porte del micro. 

Qualcuno certamente si starà chiedendo cosa av¬ 
viene se per errore si scrive: 

ledflash 4,port_b 

In questo caso, quando il Compilatore incontra led¬ 
flash carica le istruzioni relative sostituendo che- 
porta con 4 e chepin con port_b, quindi segnala 
l’errore visibile in fig.6 perché nelle istruzioni suc¬ 
cessive la macro caricata contiene istruzioni as¬ 
solutamente sbagliate: 



jrr 

port_b,4,lamp0 


res 

port_b,4 


ÌP 

lampi 

lampo 

set 

port_b,4 


lampi 



.macro 


jrr 


res 


ÌP 

chelabO 

set 

chelabl 

.endm 


È evidente che anche se l’uso delle macro è ab¬ 
bastanza facile è necessario prestare sempre mol¬ 
ta attenzione nello scrivere questi parametri. 


Il parametro [,?label] 


A questo punto abbiamo ottenuto una macro che 
setta e resetta un qualsiasi piedino di una qual¬ 
siasi porta del micro. 

Esiste però un altro problema dovuto al fatto che 
all’Interno di ledflash ci sono le labels lampo e 
lampi. Infatti ogniqualvolta vorremo utilizzare que¬ 
sta macro dovremo assicurarci di non avere già u- 
tilizzato queste labels nel nostro programma prin¬ 
cipale, perché se esistono il compilatore segnalerà 
errore. 

Inoltre se in più punti del programma principale noi 
inseriamo la macro ledflash, il compilatore sosti¬ 
tuirà ad ogni ledflash che incontra la relativa se¬ 
quenza di istruzioni ed anche in questo caso le la¬ 
bels lampo e lampi sarebbero doppie, triple ecc. 

Conviene quindi sempre parametrizzare anche le 
labels interne di una macro utilizzando il parame¬ 
tro [,?label]. 

Modifichiamo dunque il file LEDFLASH.LMA come 
qui sotto riportato: 

ledflash cheporta,\chepin,?chelab0,?chelab1 
chepin,cheporta,chelabO 
chepin,cheporta 
chelabl 

chepin,cheporta 





Nella riga .macro abbiamo inserito, oltre ai para¬ 
metri di cui abbiamo già parlato, anche i parametri 
?chelabO e ?chelab1 e nelle righe successive ab¬ 
biamo sostituito la label lampo con chelabO e la 
label lampi con chelabl. 

Il simbolo ? davanti a chelabO e chelabl definisce 
che si tratta di una label interna e quindi le label 
situate internamente alla macro e gli eventuali sal¬ 
ti di programma verranno automaticamente effet¬ 
tuati aH’interno della stessa. 

Ovviamente dovremo modificare il programma 

LAMPLED.ASM come segue: 

ledflash portb,4,lampo,lampi 

Assemblando il programma, quando il compilatore 
incontrerà questa istruzione inserirà la relativa ma¬ 
cro, sostituendo cheporta con port_b, chepin con 
4, chelabO con lampo e chelabl con lampi. 
Abbiamo cioè generato una macro dove anche le 
labels usate internamente sono parametrizzate, 
scongiurando così il pericolo che queste possano 
già esistere nel programma principale ed evitando 
molti inconvenienti. 

Ora dobbiamo soffermarci su un piccolo particola¬ 
re, perché aumentando i parametri potrebbe di¬ 
ventare più difficoltoso gestire queste macro. 

In presenza di macro molto complesse potrebbe 
infatti succedere che le labels interne siano ben 
più di due ed anche in questo caso aumentereb¬ 
bero le difficoltà. 

Inoltre potrebbe essere necessario richiamare più 
volte, in punti diversi del programma principale, la 
stessa macro, obbligando il programmatore ad in¬ 
serire delle labels sempre diverse dalle precedenti. 

Esistono comunque due soluzioni tra le quali sce¬ 
gliere per semplificare questo problema. 


PRIMA SOLUZIONE 


Consiste neH’omettere i nomi delle labels interne 
in una macro anche se questa li richiede. 

Per utilizzare questa soluzione lasceremo invaria¬ 
ta la macro così come è scritta in ledflash.LMA: 


però nel programma LAMPLED.ASM dovremo in¬ 
serire il richiamo della macro in questo modo: 

ledflash port_b,4 

omettendo volutamente le labels. 

Assemblando il programma LAMPLED.ASM, il 
compilatore inserirà le istruzioni ledflash, sosti¬ 
tuendo cheporta con port_b e chepin con 4. 

Non trovando nessuna labels, le sostituirà auto¬ 
maticamente con L2$ e L3$ al posto di chelabO e 
chelabl senza segnalare errori. 

Il compilatore è quindi in grado di provvedere au¬ 
tomaticamente alla codifica delle label interne del¬ 
la macro, perché si è utilizzato il parametro labels 
interne (?chelab ecc.), risparmiando così al 
softwarista l’impegno di inserirle. 

Per verificare se questa soluzione risulta valida pro¬ 
vate ad inserire in più punti del programma LAM¬ 
PLED.ASM un richiamo della macro ledflash, poi 
riassemblatelo con l’opzione -L. 

In fig.8 vi riportiamo il punto esatto del listato .LIS 
in cui è stato inserito il file ledflash.LMA, affinché 
possiate constatare da voi la definizione delle la¬ 
bels interne ?chelabO e ?chelab1. 

In fig.9 sono invece riportati i due punti esatti in cui 
abbiamo inserito, a poca distanza l’una dall’altra, 
l’istruzione ledflash port_b,4 omettendo la defini¬ 
zione delle labels. 

Come potete notare, nella prima macro il compi¬ 
latore ha sostituito ?chelabO e ?chelab1 con: 

L2$ e L3$ 

mentre nella seconda le ha sostituite con: 

L4$ e L5$ 

Questo ci conferma che, nel caso sia previsto nei 
parametri della macro l’utilizzo delle labels interne 



.macro 

ledflash cheporta,\chepin,?chelab0,?chelab1 


jrr 

chepin, cheporta,chelabO 


res 

chepin,cheporta 


ÌP 

chelabl 

chelabO 

set 

chepin,cheporta 

chelabl 

.endm 






Fig.7 Seguendo le lezioni sulle istruzioni del linguaggio Assembler, imparare a 
programmare i micro ST6 sarà più semplice di quanto possiate immaginare. 


(simbolo ?), il compilatore è in grado di generare 
automaticamente, in caso di omissione, queste la- 
bels assegnandole un numero consecutivo. 

Unico inconveniente che potremmo riscontrare è 
che le labels così generate siano veramente poco 
comprensibili rendendo molto difficoltosa la lettura 
del programma. 


SECONDA SOLUZIONE 


Consiste nello sfruttare la capacità che possiede la 
direttiva .macro di concatenare due stringhe pas¬ 
sando una sola label interna che diventerà un 

suffisso. 

Se seguirete questo nostro esempio scoprirete co¬ 
me in realtà sia semplice questa operazione. 

Prendiamo sempre la macro contenuta nel file led- 
flash.LMA e modifichiamola come segue: 


Nella riga .macro abbiamo inserito ?chext al po¬ 
sto di ?chelabO e ?chelab1, mentre nelle righe 
successive abbiamo sostituito: 

chelabO con lampO’chext 
chelabl con lampi ’chext 

Ora prendiamo il nostro programma principale 
LAMPLED.ASM e andiamo a modificare entrambi 
i richiami a ledflash. 

Nel primo richiamo scriviamo: 

ledflash port_b,4,r1 

e nel secondo richiamo scriviamo: 

ledflash port_b,4,r2 

Assemblando il programma LAMPLED.ASM il 
compilatore quando trova il primo ledflash inseri- 



.macro 

ledflash cheporta,\chepin,?chext 


jrr 

chepin,cheporta,lampO’chext 


res 

chepin,cheporta 

lampO’chext 

ÌP 

lampi’chext 

lampi’chext 

set 

.endm 

chepin,cheporta 









sce le istruzioni relative sostituendo cheporta con 
port_b e chepin con 4, quindi ricerca le label che 
contengono ’chext e le sostituisce con ri effet¬ 
tuando una concatenazione. 

Il risultato è che la label lampO’chext diventerà: 

lampOrl 

e la label lampi’chext diventerà: 

lampi ri 

Stessa cosa avverrà quando verrà letto il secondo 


ledflash con la differenza che lampO’chext diven¬ 
terà Iamp0r2 e lampi’chext diventerà lampi r2. 

A questo punto abbiamo creato una macro che è 
in grado di settare e resettare un bit qualsiasi di u- 
na qualsiasi variabile e che utilizza le labels in¬ 
terne significative parametrizzandole. 

Abbiamo quindi una macro che può essere richia¬ 
mata tranquillamente all’interno di qualsiasi pro¬ 
gramma senza alcuna precauzione. 

Vi è solo una piccola regola da rispettare, cioè 
quando si utilizza la concatenazione di queste la- 
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33 


.input 1 

1 LEDFLASH.LMA" 

- SOURCE 

FILE 

: 

LEDF LASH. 

. LMA- 


39 

1 

1 


.macro 

ledflash cheporta,\chepin,? chelahO,? che1ahi 

40 

1 

2 


j rr 

chepin,cheporta,chelahO 

41 

1 

3 


res 

chepin,cheporta 

42 

1 

4 


jP 

che1ahi 

43 

1 

5 

chelahO 



44 

1 

6 


set 

chepin,cheporta 

45 

1 

7 

chelahl 



46 

1 

3 


. endia 



Fig.8 Parte del listato LAMPLED.LIS generato con l’opzione -L in cui è stata inserita la 
definizione delle labels interne ?chelabO e ?chelab1 (vedi riga 39). 


119 

FOO 

□ SE7 


POO 

0SE7 


104 

ripeti 



120 

P00 

08B7 

0DD3FE 

P00 

03B7 


105 


Idi 

wdog,0 feh 

121 







106 


ledflash port h,4 

122 

P00 

08BA 

23C104 

P00 

03BA 

1 

2 


j rr 

4,port_h,L2£ 

123 

P00 

OSBD 

2BC1 

P00 

OSBD 

1 

3 


res 

4,port h 

124 

P00 

OSBF 

393C 

P00 

OSBF 

1 

4 


jP 

L3£ 

125 

P00 

OSCI 


P00 

OSCI 

1 

5 

L2* 



126 

P00 

OSCI 

3BC1 

P00 

OSCI 

1 

6 


set 

4,port_h 

127 

P00 

0SC3 


P00 

0SC3 

1 

7 

L3* 



123 






1 

S 


. endia 


129 

P00 

0SC3 

713A 

P00 

03C3 


107 


cali 

delay 

130 

P00 

0SC5 

793B 

P00 

0SC5 


103 


jP 

ripeti 

131 







109 

f 

.... 


132 







110 

f 

.... 


133 







111 


ledflash port h,4 

134 

P00 

0SC7 

A3C104 

P00 

0SC7 

1 

2 


j rr 

4,port_h,L4£ 

135 

P00 

OSCA 

ABC1 

P00 

OSCA 

1 

3 


res 

4,port_h 

136 

P00 

OSCC 

09SD 

P00 

OSCC 

1 

4 


jP 

L5* 

137 

P00 

OSCE 


P00 

OSCE 

1 

5 

L4* 



133 

P00 

OSCE 

BBC1 

P00 

OSCE 

1 

6 


set 

4,port h 

139 

P00 

OSDO 


P00 

OSDO 

1 

7 

L 5$ 



140 






1 

S 


. endia 



141 112 

Fig.9 Parte del listato LAMPLED.LIS generato con l’opzione -L in cui sono definite dal 
compilatore, in modo del tutto automatico, le labels ?chelabO e ?chelab1 con le scritte 
L2$ (vedi riga 122), L3$ (vedi riga 124), L4$ (vedi riga 134) e L5$ (vedi riga 136). 




bels la lunghezza massima delle labels ed anche 
delle variabili non deve superare gli 8 caratteri. 
Infatti, se invece di: 

ledflash port_b,4,r1 
ledflash port_b,4,r2 

avessimo scritto: 

ledflash port_b,4,ret1 
ledflash port_b,4,ret2 

avremmo generate queste label: 

lampOretl,lampi reti 
Iamp0ret2, lampi ret2 

che come noterete hanno più di 9 caratteri. 

Il compilatore in questo caso tenterà comunque di 
assemblare il programma, troncando i caratteri ec¬ 
cedenti quindi queste righe diventeranno: 

lampOret e lampi ret 
lampOret e lampi ret 

e verrà segnalato un errore perché le labels sono 
doppie e già definite. 

Come per le labels, la proprietà di concatenazione 
esiste anche per le variabili, come riportato nell’e¬ 
sempio che segue. 

Modifichiamo ledflash.LMA scrivendo: 



.macro 

ledflash cheporta, \chepin 


jrr 

chepin,portjcheporta,lampo 


res 

chepin,port_’cheporta 

lampo 

ÌP 

lampi 

lampi 

set 

.endm 

chepin,port_’cheporta 


Avrete dunque notato che nella 2°-3°-6° riga ab¬ 
biamo inserito port_’ prima di cheporta. 

In questo modo noi possiamo modificare LAM- 
PLED.ASM scrivendo solo: 

ledflash b,4 

cioè abbiamo sostituito port_b con b. 

Ricompilando il programma LAMPLED.ASM il 
compilatore quando incontra ledflash carica le i- 
struzioni relative sostituendo ’cheporta con b. 
Quindi port_’cheporta diventa port_b e la parola 
chepin diventa 4. 

Abbiamo così ottenuto un concatenamento dei pa¬ 
rametri della variabile definita port_b. 


CONCLUSIONE 


Con questi esempi pensiamo di avere sufficiente- 
mente spiegato il procedimento per creare ed uti¬ 
lizzare una macro, comunque per diventare e- 
sperti softwaristi dovrete sempre perdere un po’ di 
tempo e fare anche tante prove pratiche. 

Se ad esempio inserite nel programma LAM¬ 
PLED.ASM per due volte la macro ledflash 
port_b,4 in due punti diversi del programma, sic¬ 
come i parametri sono uguali (port_b e 4) avrete 
commesso un piccolo errore, perché richiamando 
per due volte la stessa macro il compilatore inse¬ 
rirà per due volte consecutive tutte le istruzioni del¬ 
la macro, sprecando così memoria preziosa. 

Per evitare questi sprechi di memoria conviene 
scrivere una sub-routine, che potrete ad esempio 
chiamare lampeg: 

lampeg ledflash port_b,4 
ret 

Con questa sub-routine anziché scrivere per due 
volte la parola ledflash scriverete solo: 


cali 

lampeg 

cali 

lampeg 


L’utilizzo di macro all’interno dei programmi, se da 
un lato può facilitare e snellire la stesura dei pro¬ 
grammi stessi, dall’altro permette anche di proteg¬ 
gerli dalla lettura. 

Infatti se qualcuno venisse in possesso di un sor¬ 
gente, dove nei punti principali anziché le istruzio¬ 
ni scritte in modo chiaro trovasse delle macro, non 
potrebbe decifrare il programma senza il listato di 
queste macro. 

A chi volesse proteggere i propri programmi con¬ 
sigliamo di memorizzare queste macro directory 
su supporti esterni come Floppy Disk, unità Zip o 
Hard Disk removibili da inserire solo al momento 
della compilazione in assembler. 

In questi casi dovete ricordarvi di modificare il co¬ 
mando .input. 

Ad esempio se la macro ledflash fosse stata me¬ 
morizzata su Floppy Disk anziché nella directory 
di LEDFLASH.LMA, avremmo dovuto scrivere nel 
programma questa istruzione: 

.input “a:\ledflash.LMA” 

In questo modo la macro verrà direttamente pre¬ 
levata dal Floppy Disk e solo così il programma 
riuscirà ad assemblarsi. 





Pei PROGRAMMARE i 


I microprocessori della serie ST6/B sono stati sostituiti dalla nuova se¬ 
rie ST6/C programmabile in ambiente Windows 3.1-95-98. Il linguaggio 
di programmazione non è cambiato, ma poiché nuove funzioni sono sta¬ 
te aggiunte ed altre sono state modificate, in questo articolo ci occu¬ 
peremo delle novità più rilevanti. 


La funzione SPI 

Come abbiamo spiegato nella rivista N.198, la Se¬ 
rial Peripheral Interface, meglio conosciuta come 
SPI, consente di mettere in comunicazione il no¬ 
stro micro con una EEprom esterna oppure con 

uno Shift register o con un altro integrato, se¬ 
condo uno standard di trasmissione e ricezione 
dati in modalità seriale sincrona. 

Le possibilità offerte da questa particolare funzio¬ 
ne, di cui sono dotati anche i nuovi microproces¬ 
sori della serie ST6/C, sono molteplici e offrono al 
programmatore non pochi vantaggi, soprattutto 
considerando il fatto che svolgendosi la trasmis¬ 
sione e ricezione dati in maniera del tutto auto¬ 
matica, il microprocessore può nel frattempo ese¬ 
guire le altre istruzioni del programma. 

In sostanza, le specifiche della funzione SPI in con¬ 
figurazione “Tree wire Half Duplex with Master/Sla¬ 


ve select”, propria degli ST6260-65, permettono di 
attivare una comunicazione Half Duplex su tre fili 
con selezione Master e Slave. 

Dei piedini e dei registri coinvolti nella ricezione 
- trasmissione dati ci siamo occupati, con parti¬ 
colare riguardo, nella rivista N.198, che vi consi¬ 
gliamo di rileggere. 

In questa circostanza è invece utile ricordare che 
la SPI si attiva predisponendo adeguatamente cer¬ 
ti registri, diversamente i piedini coinvolti continue¬ 
ranno a svolgere le normali funzioni per cui erano 
stati in precedenza programmati. 

Vediamo dunque subito quali differenze ci sono tra 
la serie B e la nuova serie C degli ST6. 

Nella versione degli ST6/B, per attivare la SPI in 
Master Mode era necessario configurare il piedi¬ 
no PC4 (Sck) di Porta C come Output Push Pulì 
e settare a 1 il bit Spclk del registro spmc (Spi 
Mode Register). 




































































Il bit Spclk, Base Clock Selection, consente infatti 
di selezionare il clock e informa il microcontrollo¬ 
re se il clock sarà interno (bit ale dunque atti¬ 
vazione del Master Mode) o esterno (bit a 0 e dun¬ 
que attivazione dello Slave Mode). 

Nella versione degli ST6/C, per attivare la SPI in 
Master Mode, i piedini PC3 (Sout) e PC4 (Sck) 

devono essere configurati in Reset State, cioè: 

pdir_c = OOOOOOOOb 
popt_c = OOOOOOOOb 
port_c = OOOOOOOOb 

perché è sufficiente settare a 1 il bit Spclk del re¬ 
gistro spmc (Spi Mode Register) per configurare 

automaticamente il PC4 di Porta C come Output 
Push Pulì. 

I bit relativi a pdir_c e popt_c non devono essere 
assolutamente modificati e quindi devono rimane¬ 
re in Reset State. 


Ponete particolare attenzione al fatto che nella terza 
riga (vedi port_c) abbiamo configurato a 1 il piedino 
PC2 (00000100) in modalità Input No Pull-Up; nella 
sesta riga, avendo settato a 1 il bit 2 del registro 
spmc (00010100), abbiamo attivato la condizione di 
Start Selection (vedi rivista N.198) e nella settima ri¬ 
ga (vedi spda) abbiamo inserito il valore esadeci- 
male C8h che corrisponde al valore decimale 200. 

Dopo aver visto come va configurata la funzione 
SPI per attivare il Master Mode nei nuovi micro del¬ 
la serie C, ora descriviamo alcune importanti ca¬ 
ratteristiche di questi nuovi microprocessori e le 
funzioni dell’option byte, che abbiamo già avuto 
modo di presentarvi nella rivista N.202. 

Il dispositivo LFAO 

Nella versione C degli ST62X è stato inserito un o- 
scillatore ausiliario interno di emergenza siglato 


nuovi MICRO serie ST6/C 


Quando settiamo a 1 il bit M0 del registro mise (Mi- 
scellaneous), che attiva la SPI per la trasmissio¬ 
ne dati, automaticamente il PC3 di Porta C si con¬ 
figura come Output Push Pulì. 

Anche in questo caso i bit relativi a pdir_c e popt_c 
non devono essere modificati, cioè devono rima¬ 
nere in Reset State. 

Per capire meglio le peculiarità della programma¬ 
zione della SPI nei micro ST6 della versione C vi 
portiamo un semplice esempio. 


Ammesso di voler trasmettere il valore 200 trami¬ 
te SPI da un dispositivo in Master Mode ad un di¬ 
spositivo Slave, in modalità 8 bits alla velocità di 
9600 B/Rate, in Polarità e Fase normali, senza Fil- 


tro e Interrupt, le 

istruzioni saranno: 

Idi 

pdir_c,OOOOOOOOb 

Idi 

popt_c,OOOOOOOOb 

Idi 

port_c,000001 OOb 

Idi 

misc,1 

Idi 

spdv,01000110b 

Idi 

spmc,00010100b 

Idi 

spda,C8h 

set 

7,spmc 

loop jrs 

7,spmc,loop 


LFAO (Low Frequency Auxiliary Oscillator). 
Questo oscillatore può essere attivato in sostitu¬ 
zione dell’oscillatore principale settando a 1 il bit 
2 denominato OSC. OFF, cioè Main Oscillator Off, 
del registro adcr dell’A/D converter (vedi fig.1). 


bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bitO 


EAI 

E0C 

STA 

PDS 

// 

ose. 

OFF. 

// 

// 


Fig.1 Gli ST6 della serie C hanno un oscil¬ 
latore ausiliario interno di emergenza che 
può essere attivato ponendo a livello logi¬ 
co 1 il bit 2 (vedi OSC. OFF) del registro AD¬ 
CR dell’A/D converter. 


Attivando questo dispositivo si riduce drastica¬ 
mente la frequenza interna di clock ad una fre¬ 
quenza compresa tra 0,8-1 MHz, che permette al 
microcontrollore di eseguire tutte le sue funzioni, 
anche se a velocità ridotta. Allo stesso tempo si 
riduce la corrente di assorbimento del micro, che 
scende ad un valore di circa 1 mA. 

Solitamente questo dispositivo si attiva solo quan¬ 
do non necessitano elevate velocità di esecuzione 
oppure per ridurre il consumo di corrente quando 
il micro è alimentato da un Gruppo di Continuità. 















Può inoltre risultare utile per diminuire il rumore 
durante una conversione A/D in concomitanza con 
l’utilizzo dell’istruzione wait (modalità stand-by). 
Nel paragrafo relativo all’A/D sync, riportato in que¬ 
sto articolo, parleremo proprio di questo caso in 
modo esauriente. 

Resettando il bit OSC. OFF, ponendolo cioè a 0, 
si riattiva automaticamente l’oscillatore principale. 

La funzione LVD 

Nelle versioni degli ST6 precedenti alla C, la con¬ 
dizione di Reset del microprocessore veniva atti¬ 
vata quando si verificava una di queste condizioni: 

1 - all’accensione del micro (Power On Reset), 

2 - quando il watchdog si decrementava fino a 0, 

3 - quando il piedino di Reset veniva esternamente 
cortocircuitato a massa. 

Nella versione C è stata prevista una quarta con¬ 
dizione di Reset, che si può attivare in fase di pro¬ 
grammazione settando la funzione LVD o Low Vol- 
tage Detector dell’option byte. 

Con LVD attivato, cioè settato a 1, quando la ten¬ 
sione di alimentazione, che deve essere di 5 volt, 
scende al disotto di 3,7-3,5 volt, il micro si posizio¬ 
na automaticamente sul vettore di interrupt reset. 
In altre parole entra nel cosiddetto Reset Statico 
sospendendo temporaneamente ogni attività sen¬ 
za resettarsi. Quando la tensione di alimentazione 
sale nuovamente sopra i 4 volt, il micro riparte ed 
esegue l’eventuale routine legata al vettore di in¬ 
terrupt RESET. 

In fig.2 è riportato il diagramma di intervento della 
funzione LVD. 

C’è anche un altro caso in cui l’attivazione della 
funzione LVD interviene provocando una condizio¬ 
ne di Reset temporaneo. 


Vdd 



Fig.2 Utilizzando la funzione LVD, viene at¬ 
tivato in modo automatico un reset tempo¬ 
raneo se la tensione di alimentazione do¬ 
vesse scendere sotto i 3,5 volt. 


Quando si accende il microcontrollore, si attiva il 
Power On Reset (POR) per cui tutte le porte di 
I/O sono inizialmente configurate come input pull- 
up e non viene eseguita alcuna istruzione. 

Non appena la tensione di alimentazione raggiun¬ 
ge i 2,5 - 3,0 volt, l’oscillatore inizia a generare la 
sua frequenza di clock e poco dopo il micro inizia 
ad eseguire la prima istruzione. 

Questa fase è abbastanza critica, perché se per 
vari motivi la tensione non raggiungesse i 4,1 volt 
o non fosse stabile, il micro potrebbe presentare 
anomalie di funzionamento nella partenza o du¬ 
rante l’esecuzione del programma. 

Attivando la funzione LVD, il micro esegue sola¬ 
mente la fase di POR, dopodiché attende che la 
tensione raggiunga un valore superiore ai 4 volt 
prima di iniziare ad eseguire tutte le istruzioni del 
programma (vedi fig.3). 

Garantendo una tensione stabile e, di conseguen¬ 
za una frequenza di clock stabile, si evitano false 
partenze di programmi e altre possibili anomalie di 
funzionamento. 

In conclusione la funzione LVD attiva una condi¬ 
zione di Reset temporaneo in due occasioni: 

1 - nella fase di inizializzazione o POR, fino a 
quando la tensione non raggiunge un valore supe¬ 
riore a 4 volt; 

2 - durante l’esecuzione del programma, quando 
la tensione scende al disotto di 3,7-3,5 volt. 

In entrambi i casi la condizione di Reset tempora¬ 
neo permane fino a quando la tensione non si è 
stabilizzata sopra i 4 volt. 

Lo stadio OSG 

AH’interno dei nuovi micro della serie C è stato in¬ 
serito uno stadio denominato OSG (Oscillator Sa- 
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Fig.3 La funzione LVD mantiene un reset 
temporaneo nella fase di inizializzazione fi¬ 
no a quando la tensione di alimentazione 
non raggiunge un valore maggiore di 4 volt. 
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Settando a 1 la funzione OSG dell’option byte, si 
attiva un filtro digitale da 8 MHz che filtra tutti gli 
impulsi spuri che si verificano entro un tempo di 
62,5 microsecondi dal cambiamento di stato del 
clock, rendendo in tal modo la frequenza di clock 
più stabile. 

In questo modo la frequenza massima di clock non 
potrà mai superare gli 8 MHz. 

Poiché il suo periodo corrisponde a un tempo di: 

1 : 8 = 0,125 millisecondi 


Fig.4 Schema a blocchi dello stadio OSG di 
cui sono dotati i micro ST6/C. Questo di¬ 
spositivo deve essere attivato in fase di 
programmazione settando a 1 l’option byte 
denominato Osg enable. 


fe Guard), che si può attivare settando a 1 l’option 
byte Osg enable o disattivare settandolo a 0. 

In fig.4 è riportato lo schema a blocchi di questo 
stadio che se attivato svolge 3 importanti funzioni: 

- funzione Filtro 

- attivazione LFAO 

- limitatore frequenza di clock 

1 - La funzione FILTRO 

Quando si utilizza un oscillatore esterno per ge¬ 
nerare la frequenza di clock può verificarsi che l’in¬ 
gresso Ose in (ingresso oscillatore) capti degli im¬ 
pulsi spuri che potrebbero generare delle fre¬ 
quenze di clock superiori a quelle ottimali o addi¬ 
rittura bloccare le funzioni del micro. 


pari a 125 microsecondi, ogni cambio di stato da 
1 a 0 o viceversa avviene ogni 62,5 microsecondi. 

Ogni cambio di stato del clock viene mantenuto 
stabile dall’OSG per un tempo massimo di 62,5 mi¬ 
crosecondi, pertanto qualsiasi impulso spurio che 
entrasse sull’ingresso del micro in questo lasso di 
tempo, verrebbe ignorato (vedi fig.5). 

2 - L’attivazione del dispositivo LFAO 

Se l’OSG non rileva la frequenza di clock genera¬ 
ta dall’oscillatore principale, attiva automatica- 
mente il dispositivo LFAO, cioè l’oscillatore inter¬ 
no di emergenza. 

In questo modo viene generata una frequenza di 
clock compresa tra 0,8-1 MHz che consente al mi¬ 
cro di continuare a funzionare anche se più lenta¬ 
mente (vedi fig.6). 

Sempre automaticamente, l’OSG provvede a di¬ 
sattivare il dispositivo LFAO quando l’oscillatore 
principale torna a generare la sua frequenza di 
clock. Disabilitando il dispositivo LFAO, il micro 
può riprendere a lavorare a velocità regolare. 
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Fig.5 Con l’Osg enable settato a 
1, si attiva un filtro digitale da 8 
MHz che ha il compito di mante¬ 
nere bloccato ogni cambio di sta¬ 
to logico del clock per un tempo 
di 62,5 microsecondi. Quindi se 
in questo lasso di tempo doves¬ 
sero entrare degli impulsi spuri 
(vedi figura al centro), verrebbe¬ 
ro ignorati e la frequenza di clock 
sarebbe perfettamente pulita (ve¬ 
di figura in basso). 

































































3 - La limitazione della frequenza di clock 

L’ultima funzione del circuito OSG è quella di di¬ 
minuire automaticamente la frequenza interna di 
clock nel caso dovesse abbassarsi la tensione di 
alimentazione del micro. 

Vediamo come ciò avviene in pratica. 

Se la foscn, cioè la frequenza di clock di 8 MHz, 
rimane sempre costante con una tensione com¬ 
presa tra 4,5-5 volt, nel momento in cui la tensio¬ 
ne di alimentazione scende al disotto di 4,5 volt, 
l’OSG provvede ad abbassare la frequenza di clock 
interna a 4 MHz, anche se il quarzo continua ad o- 
scillare a 8 MHz. 

Se questa tensione scende al disotto di 3,5 volt, 
l’OSG abbassa ulteriormente la sua frequenza in¬ 
terna di clock a 2 MHz. 

Questa funzione è molto utile perché, se per un 
qualsiasi motivo dovesse abbassarsi la tensione di 
alimentazione, il micro potrà continuare a lavorare 
anche se ad una velocità ridotta. 

È ovvio che nel caso il micro svolgesse funzioni di 
timer, di orologio ecc., cioè funzioni legate al tem¬ 
po, con l’attivazione dell’OSG al variare della ten¬ 
sione di alimentazione si avrebbero delle variazio¬ 
ni non regolari sui tempi di lavoro. 

In questi particolari casi potrebbe convenire al pro¬ 
grammatore non limitare la frequenza tramite 
l’OSG, ma, come abbiamo già avuto modo di dire, 
far operare in automatico un reset temporaneo tra¬ 
mite la funzione LVD tutte le volte che la tensione 
di alimentazione scende sotto i 3,7-3,5 volt. 

Qualcuno potrebbe obiettare che non c’è differen¬ 
za tra l’attivazione del LFAO, precedentemente 


spiegata, e la limitazione della frequenza di clock 
al variare della tensione. 

Quando l’OSG rileva che viene a mancare la fre¬ 
quenza di clock dall’oscillatore principale, attiva 
il dispositivo LFAO, cioè l’oscillatore interno di e- 
mergenza che genera una frequenza di clock com¬ 
presa tra 0,8 -1 MHz. 

Se l’OSG rileva che l’oscillatore principale fun¬ 
ziona regolarmente, ma per un motivo qualsiasi la 
tensione di alimentazione scende al disotto di 4,5 
volt, attiva il limitatore di frequenza portando la fre¬ 
quenza di clock ad un valore inferiore. 

WATCHDOG 

In questo paragrafo ci occupiamo in special modo 
di due funzioni dell’Option Byte e della loro stret¬ 
ta relazione con le istruzioni wait e stop. 

Watchdog activation 

0 = Watchdog Software 
1 = Watchdog Hardware 

External Stop Mode Control 

0 = Disattivato 
1 = Attivato 

Prima della comparsa sul mercato dei micro ST6 
della serie C, se si voleva gestire il Watchdog tra¬ 
mite software si doveva scegliere il micro siglato 
SW o SWD, mentre se si voleva gestire il Watch¬ 
dog tramite hardware si doveva scegliere il micro 
siglato HW o HWD. 

Nella nuova serie C il tipo di Watchdog è selezio¬ 
nabile tramite l’option byte. 



Fig.6 Quando l’OSG non rileva la 
frequenza di clock generata 
dall’oscillatore principale, auto¬ 
maticamente attiva l’oscillatore 
interno di emergenza LFAO che, 
generando una frequenza a 0,8-1 
MHz, consente al micro di conti¬ 
nuare a eseguire le istruzioni. 
Quando l'oscillatore principale 
torna a generare la sua frequenza 
di clock, l’OSG disabilita in modo 
automatico l'oscillatore LFAO. 




























































Watchdog hardware 


Settando a 1 la funzione Watchdog activation, il 
watchdog diventa di tipo HW (hardware), pertanto 
non si può più disattivare tramite software. 

Questo significa ovviamente che non è possibile u- 
tilizzare né l’istruzione wait né l’istruzione stop. 

Infatti, l’istruzione wait blocca il program counter 
e di conseguenza l’esecuzione del programma, ma 
non blocca l’oscillatore principale e di conseguen¬ 
za il watchdog si decrementa fino a 0 resettando 
il microprocessore. 

L’istruzione stop dovrebbe in teoria bloccare an¬ 
che l’oscillatore e il watchdog, ma essendo que¬ 
st’ultimo di tipo HW non si può disattivare e si ot¬ 
tiene lo stesso risultato dell’istruzione wait. 

Se però si setta a 1 l’option byte denominato Ex- 
ternal Stop Mode Control e contemporaneamen¬ 
te si setta a 1 anche l’option byte denominato NMI 
pin pull-up a 1 (vedi rivista N.202), si pongono i 
presupposti necessari per utilizzare l’istruzione 
stop anche con un watchdog di tipo HW. 

A queste condizioni, quando il programma incon¬ 
tra l’istruzione stop, il watchdog viene tempora¬ 
neamente bloccato e il micro entra nella condizio¬ 
ne halt mode o stop mode fermandosi compieta- 
mente. 

Nella condizione di stop mode il micro blocca tut¬ 
te le sue funzioni compreso l’oscillatore lasciando 
attivo solo l’interrupt sul piedino di NMI. 

Per uscire dalla condizione di stop mode si deve 
far giungere sul piedino NMI un fronte di discesa, 
attivando così un interrupt che potrà essere e- 
ventualmente gestito con una routine software. 


Watchdog software 


Settando a 0 la funzione Watchdog activation, il 
watchdog diventa di tipo SW (software), pertanto 
per attivarlo si dovrà settare a 1 il bit denominato 
C e settario a 0 per disattivarlo (vedi fig.7). 


Un Watchdog SW può essere disattivato tramite il 
programma e dunque si possono tranquillamente 
utilizzare le istruzioni wait e stop. 


bit 7 

bit 6 

bit 5 

bit 4 

bit 3 

bit 2 

bit 1 

bitO 

TO 

TI 

T2 

T3 

T4 

T5 

SR 

C 


Fig.7 Se la funzione Watchdog viene setta¬ 
ta a 0, il watchdog è di tipo SW (software), 
quindi per attivarlo si deve settare a 1 il bit 
C del registro di Watchdog. 


Tenete presente che se disattivate il watchdog, 
potrete sempre riattivarlo, ma una volta attivato 
non potrete più disattivarlo. 

In questo caso potrà essere gestito come già spie¬ 
gato nel paragrafo dedicato al Watchdog HW. 

Per disattivare il watchdog dovete scrivere come 
prima istruzione del programma: 

Idi wdog,feh 

Dopo non è più necessario gestire il Watchdog 
aH’interno del programma. 


ADC sync 

L’A/D converter presente nei micro ST62 è un 
convertitore analogico - digitale a 8 bit in grado 
di eseguire una conversione in un tempo di 70 na¬ 
nosecondi con una frequenza di clock di 8 MHz. 

La conversione di un segnale analogico in un se¬ 
gnale digitale viene eseguita con una sequenza di 
approssimazioni successive, utilizzando per il 
clock la frequenza generata dall’oscillatore princi¬ 
pale divisa per 12. 

Lavorando quindi per approssimazioni successive, 
se nel micro sono presenti varie fonti di rumore (ti¬ 
mer attivo, Vdd instabile - PWM ecc.), si potrebbe 
avere sul valore finale un errore di 1 o 2 bit. 

Per evitare questo errore in molti nostri programmi 
(vedi dischetto DF.1208) abbiamo utilizzato la tec¬ 
nica del campionamento, che consiste nel ripe¬ 
tere la stessa conversione A/D per 16, 32, 64 vol¬ 
te e poi dividere il risultato per il numero scelto. 

In questo modo si ottiene una maggiore precisione 
però si ha lo svantaggio di allungare notevolmente 
il tempo di esecuzione della routine di conversione. 

Per eliminare le fonti di rumore ed ottenere un ri¬ 
sultato finale più preciso durante una conversione 
A/D utilizzando i micro con watchdog SW, veniva 
consigliato di usare l’istruzione wait subito dopo l’i¬ 
struzione Idi, come qui sotto riportato: 

Idi adcr,10110000b 
wait 

Purtroppo se il programma utilizza più di un clock 
(timer - PWM ecc.), prima che l’istruzione wait rie¬ 
sca a mettere il micro in stand-by la conversione 
è già completata, quindi si continuano ad avere 
degli errori sul risultato finale. 














Per ovviare a questo problema è stata aggiunta la 
funzione ADC Syncro nell’option byte dei micro 
della serie C. 

Attivando a 1 questa funzione, la conversione A/D 
parte non con l’istruzione Idi, ma con l’istruzione wait, 
quando cioè il micro è in condizione di stand-by. 
Chiaramente l’istruzione wait deve essere posta 
subito dopo l’istruzione Idi adcr,10110000b, altri¬ 
menti la conversione A/D non risulterà corretta. 

Di seguito riportiamo un piccolo esempio di una 
routine di conversione A/D per ST62/65C con la 
modalità ADC synchro attivata. Ovviamente il wat- 
chdog è di tipo SW ed è disattivato. 

addr .def OdOh ;dati a/d conv. 

adcr .def Odi h registro a/d 


;-Inizio programma 

inizio Idi wdog,0feh ; disattivo wdog 


;-routine A/D 

adcon Idi adcr,10110000b 


wait 

;stand-by 

nop 

;va sempre inserito 

Id a,addr 

;risultato a/d in a 


;-subroutine di interrupt A/D 

tadjnt Idi adcr,0001 OOOOb 
reti 

;-vettori di interrupt 

.org Offh 

jp tadjnt ;interrupt a/d e timer 

jp artjnt 

jp CSJnt 

jp ABJnt 

.org Offch 

jp nmijnt 

jp inizio 

.end 


Idi ior,10h ;Global Interrupt On 

. Utilizzando la funzione ADC Syncro riuscirete ad 

ottenere una conversione A/D molto precisa. 













LA DIRETTIVA JFC 


Obiettivo di questo articolo è spiegarvi l’utilizzo di 
un gruppo di direttive in uso nel linguaggio As¬ 
sembler per ST6 che, utilizzate durante la stesu¬ 
ra di programmi e macro, vengono elaborate già 
in fase di compilazione snellendo l’esecuzione del 
programma o della macro stessa. 

Non dobbiamo infatti dimenticare che la quasi to¬ 
talità dei programmi contiene al suo interno istru¬ 
zioni, sub-routine, moduli che effettuano delle 
scelte in base al valore di variabili, costanti, e- 
spressioni o condizioni logiche. 

In base ai valori riscontrati o ottenuti, si attivano al¬ 
tre istruzioni o sub-routine o si effettuano salti di 
programma oppure si richiamano moduli ecc. 

Quando si compila un programma per generare il 
file in formato .HEX, anche le istruzioni, le sub¬ 
routine e i moduli che comportano una scelta ge¬ 
nerano un codice eseguibile. 

Questo significa che le scelte vengono effettuate 
durante l’esecuzione del programma, cioè quando 
il programma sta effettivamente funzionando. 

In alcuni casi però ciò porta a un appesantimen¬ 
to del programma o dà luogo a una maggiore dif¬ 
ficoltà durante la fase di test e di simulazione. 


modo automatico durante la compilazione del pro¬ 
gramma, in modo da ottenere un completo pro¬ 
gramma eseguibile già parametrizzato. 


Queste direttive sono: 


.ite 

.else 

.ende 

.mexit 


= direttiva che equivale a se 
= direttiva che equivale ad altrimenti 
= direttiva che equivale a fine 
= direttiva che equivale a uscita for¬ 
zata 


.error 


.warning 


.display 


= direttiva che mostra un messaggio 
di errore impedendo al compilatore 
di generare il programma .HEX 
= direttiva che pur mostrando un mes¬ 
saggio di errore consente al compila¬ 
tore di generare il programma .HEX 
= direttiva che provvede a visualizza¬ 
re sul monitor un messaggio 


Per farvi capire a cosa servono le tre direttive: 


.ifc 

.else 

.ende 


Esistono tuttavia delle direttive che, in molti casi, analizziamo insieme una situazione che, verifi- 
possiamo utilizzare per effettuare queste scelte in candosi spesso, vi è sicuramente nota. 

















































































Tutte le volte che si fa la spesa al supermercato, 
dopo aver riempito il carrello ci si avvia alla cassa 
e per pagare la merce acquistata si può scegliere 
fra diverse modalità, tutte però subordinate a pre¬ 
cise condizioni: 

- se la cassa accetta assegni 

- pago con assegno 

- altrimenti 

- se la cassa accetta la carta di credito 

- pago con carta di credito 

- altrimenti 

- se la cassa accetta il bancomat 

- pago con bancomat 

- altrimenti 

- pago in contanti 

- fine delle possibilità 

Nel nostro esempio le parole “se accetta” rappre- 


vera si passa all’ultima possibilità e quindi non ri¬ 
mane altro che: 

- altrimenti 

- pago in contanti 

- fine delle possibilità. 

Le tre direttive .ifc, .else, .endc devono dunque es¬ 
sere utilizzate in questo ordine: 

.ifc: dopo aver definito la condizione e i suoi og¬ 
getti, vanno inserite le istruzioni da assemblare so¬ 
lo in presenza di una condizione vera. 

.else: di seguito vanno inserite le istruzioni da as¬ 
semblare solo se la condizione precedente non ri¬ 
sulta vera. 

.endc: stabilisce la fine delle scelte. 


«ASSEMBLER m ST6 


In questo articolo ci occupiamo di un gruppo di direttive del linguaggio 
Assembler per ST6 che, opportunamente utilizzate, vi consentono di ot¬ 
tenere con la compilazione un programma eseguibile parametrizzato. 


sentano la condizione, mentre “assegno - carta di 
credito - bancomat” sono i suoi oggetti. 

Quindi l’azione “pago con assegno” si può ese¬ 
guire solo nel caso risulti vera la condizione in cui 
la cassa accetti gli assegni. 

Se questa condizione non è vera si passa all’altra 
possibilità verificando la seconda condizione: 

- altrimenti 

- se accetta la carta di credito 


eq 


ne 


gt 


It 


le 


ge 


Le condizioni vengono espresse con queste sigle: 
= significa è uguale a 0 
= significa non è uguale a 0 
= significa è maggiore di 0 
= significa è minore di 0 
= significa è minore o uguale a 0 
= significa è maggiore o uguale a 0 


Quindi l’azione “pago con carta di credito” si può 
eseguire solo nel caso risulti vera la condizione in 
cui la cassa accetti la carta di credito. 


df 


significa è definita 


ndf 


significa non è definita 


Se anche questa condizione non è vera, si passa 
alla terza possibilità verificando la terza condizione: 

- altrimenti 

- se accetta il bancomat 

e se anche questa ultima condizione non risulta 


È ovvio che ognuna di queste condizioni risulterà 
vera oppure non vera rispetto alla definizione del 
suo oggetto. 

Cercheremo perciò ora di spiegarvi in maniera det¬ 
tagliata ed esauriente come usare le condizioni 
della direttiva .ifc. 



















eq = condizione uguale a 0 


gt = condizione maggiore di 0 


Se ad esempio scriviamo: 


.ifc 

eq valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.ende 



Se inseriamo gt prima di valx 


.ifc 

gt valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.ende 



Quando il compilatore incontra: 

.ite eq valx 

verifica se il valore di valx è uguale a 0 ed as¬ 
sembla l’istruzione: 

Idi coms,8 

solo se la condizione è vera. 

Se invece valx e diverso 0, noi abbiamo una con¬ 
dizione non vera quindi assembla l’istruzione che 
si trova dopo la direttiva .else: 

.else 

Idi coms,13 

Ricordate che per diverso da 0 si intende un valo¬ 
re che può essere maggiore o minore di 0. 

La direttiva .ende segnala al compilatore la fine 
del blocco della condizione e deve essere sempre 
inserita come ultima istruzione. 

A questo punto vi chiederete come fa valx a con¬ 
tenere un valore uguale a 0 o diverso da 0. 

Gli esempi che seguono chiariranno ogni dubbio. 


ne = condizione non uguale a 0 


Si tratta della condizione opposta alla precedente, 
per cui se sostituiamo eq con ne: 


.ifc 

ne valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.ende 



Il compilatore assembla: 

Idi coms,8 

solo nel caso in cui valx risulti diverso da 0 altri¬ 
menti assembla: 

Idi coms,13 

poi passa alla direttiva .ende, che gli segnala la fi¬ 
ne del blocco della condizione. 


Il compilatore assembla: 

Idi coms,8 

solo nel caso valx risulti maggiore di 0; se invece 

è uguale o minore di 0 assembla: 

Idi coms,13 

È sottinteso che, in questo caso, il compilatore è 
in grado di riconoscere anche un valore negativo 
come risultato di una espressione. 

Nel secondo esempio che chiude questo articolo, 
avremo modo di spiegarvi come ciò accada. 


It = condizione minore di 0 


Se inseriamo It prima di valx: 


.ifc 

It valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.ende 



Il compilatore assembla: 

Idi coms,8 

solo nel caso in cui valx risulti minore di 0; se in¬ 
vece risulta uguale o maggiore di 0 assembla l’i¬ 
struzione: 

Idi coms,13 

quindi passa alla direttiva .ende, che gli segnala la 
fine del blocco della condizione. 


le = condizione minore o uguale a 0 


Se inseriamo le prima di valx: 


.ifc 

le valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.ende 













Il compilatore assembla: 

Idi coms,8 

solo se valx risulta minore o uguale a 0. 

Se valx è maggiore di 0 assembla l’istruzione: 

Idi coms,13 

quindi passa alla direttiva .endc, che gli segnala la 
fine del blocco della condizione. 


ge = condizione maggiore o uguale a 0 


Se scriviamo ge prima di valx: 


■ ifc 

ge valx 

Idi 

coms,8 

.else 


Idi 

coms,13 

.endc 



Il compilatore assembla: 

Idi coms,8 

solo nel caso valx risulti maggiore o uguale a 0. 
Se valx è minore di 0 assembla l’istruzione: 

Idi coms,13 

quindi passa alla direttiva .endc, che gli segnala la 
fine del blocco della condizione. 


df = condizione definita 


Nel caso si volessero inserire più macro o più mo¬ 
duli all’Interno di un programma principale, la con¬ 
dizione df ci permetterà di controllare e quindi di 
gestire (ad esempio per segnalare un errore, per 
modificare un valore, ecc.) se esiste una variabile, 
un’etichetta o una costante già definita in altri pun¬ 
ti del programma con lo stesso nome. 

.ifc df pippo 

.display “pippo già definito” 

.endc 

Solo se pippo risulta già definito, il compilatore 
assembla: 

.display “pippo già definito” 

facendo apparire sul monitor il messaggio “pippo 
già definito”. 


ndf = condizione non definita 


È la condizione opposta alla precedente, per cui la 
condizione ndf ci permetterà di controllare e quin¬ 
di di gestire (ad esempio per segnalare un errore, 
per modificare un valore, ecc.) se esiste una va¬ 
riabile, un’etichetta o una costante che non sia an¬ 
cora stata definita in altri punti del programma con 

10 stesso nome. 

.ifc ndf pippo 

.display “pippo non definito” 

.endc 

11 compilatore assembla: 

.display “pippo non definito” 

solo se pippo non risulta definito. In questo caso 
vedremo apparire sul monitor il messaggio “pippo 
non definito”. 

PRIMO ESEMPIO 

Per completare quanto appena spiegato, abbiamo 
scritto un programma, che abbiamo chiamato SE- 
RIAL.ASM (vedi il listato in fig.1), che effettua una 
elaborazione di dati e provvede a trasmetterli ad 
un dispositivo qualunque in modalità seriale a- 
sincrona tramite un piedino di una porta. 

La velocità di trasmissione viene regolata tramite 
un’opportuna configurazione del timer del micro. 

Infatti, a seconda delle necessità, è la macro che 
abbiamo chiamato setbaud che effettua la scelta 
e il settaggio della velocità di trasmissione seriale 
asincrona con la possibilità di scegliere tra queste 
quattro velocità: 9600 - 4800 - 2400 -1200 baud. 

Il listato completo della macro setbaud è visibile in 
fig.2, mentre in fig.1 è visibile la parte del pro¬ 
gramma sorgente nella quale durante la compila¬ 
zione viene inserita la macro. 

Come potete notare dalla fig.2, si tratta di una ma¬ 
cro (setbaud) parametrizzata (m_baud), pertanto 
durante la compilazione il valore (t_baud), definito 
nella riga del file sorgente che richiama questa ma¬ 
cro, verrà “passato” e sostituito nella macro stessa 
utilizzando la Common Area. 

Questo è ciò che succede anche se, come nel no¬ 
stro caso, i nomi usati per definire i parametri nei 
file SERIAL.ASM e SETBAUD.LMA non sono gli 
stessi. 

Nota: per rinfrescarvi la memoria sulla formazione 








Fig.1 LISTATO del PROGRAMMA SERIAL.ASM 


t_baud 

. set 

96 


.input 

"SETBAUD.LMA 

main 


Idi 

wdog,Ofeh 


cali 

init_a 


cali 

init_p 


setbaud 

t_baud 

loop 

idi 

wdog,Ofeh 


cali 

elabor 


cali 

trasmx 


jp 

loop 


; ricarica il Watchdog 
;inizializzo le variabili 
;inizializzo le porte 
;macro config. velocita trasm/baud 
; ricarica il Watchdog 
/elaborazione dati 
/trasmissione seriale asincrona 


Fig.2 LISTATO del PROGRAMMA SETBAUD.LMA 

.macro 

setbaud 

m_baud 







. if c 

df set_tcr 

r 






warning 

endc 

"set_tcr già' definito" 







. if c 

df set_psc 

r 






.warning 
. endc 

"set_psc già' definito" 







. if c 

eq m_baud - 12 

r 

1200 - 

— 

- 

-+ 

set_tcr 

. set 

140 

r 






set_psc 

. set 

2 

r 







.display 

"1200 BAUD" 

r 







. else 


r 

altrimenti 






. if c 

eq m_baud - 24 

r 

2400 - 

— 

- 

-+ 


set_tcr 

. set 

140 

r 




1 


set_psc 

. set 

1 

r 




1 



.display 

"2400 BAUD" 

r 




1 



. else 


r 

altrimenti 



1 



. if c 

eq m_baud - 48 

r 

4800 - 

-4 


1 


set_tcr 

. set 

140 

r 




1 


set_psc 

. set 

0 

r 




1 



.display 

"4800 BAUD" 

r 




1 



. else 


r 

altrimenti 



1 



. if c 

eq m_baud - 96 

r 

9600 - 

-+ 


1 


set_tcr 

. set 

70 

r 


1 


1 


set_psc 

. set 

0 

r 


1 


1 



.display 

"9600 BAUD" 

r 


1 


1 



. else 


r 

altrimenti 

1 


1 



. error 

"ERRORE SELEZ.BAUD" 

r 

ERRORE 

1 


1 



.mexit 


r 


1 


1 



. endc 


r 

— 

- + 


1 



. endc 


r 

— 

-+ 

1 



. endc 


r 

— 

— 

- 

+ 



. endc 


r 

— 

— 

- 

— + 


. endm 


r 

fine macro 


























e l’utilizzo delle macro, vi consigliamo di rileggere 
l’articolo a loro dedicato, che abbiamo pubblicato 
sulla rivista N.203. 

Vediamo dunque passo passo cosa succede quan¬ 
do lanciamo la compilazione del programma sor¬ 
gente SERIAL.ASM. 

Tralasciamo tutte le istruzioni iniziali, che al fine 
dell’argomento di questo articolo non interessano, 
e soffermiamoci sull’istruzione: 

t_baud .set 96 

Come già sapete, quando il compilatore incontra 
la direttiva .set assegna un valore, che nel nostro 
caso è 96, alla costante t_baud. 

L’istruzione successiva: 

.input “SETBAUD.LMA” 

ci serve per definire setbaud come macro, in mo¬ 
do che il compilatore, quando incontra questo no¬ 
me, inserisca il contenuto del file SETBAUD.LMA, 
cioè della macro per settare la velocità di trasmis¬ 
sione (vedi fig.2), all’interno del programma SE¬ 
RIAL.ASM. 

Le tre istruzioni successive: 


mairi 

Idi 

wdog,0feh 


cali 

init_a 


cali 

init_p 


servono in esecuzione per caricare il Watchdog e 
inizializzare sia le variabili del programma sia le 
porte del micro coinvolte. 

Quando il compilatore Assembler arriva a: 

setbaud t_baud 

riconosce che setbaud è una macro e pertanto la 
sostituisce con le istruzioni relative passando, co¬ 
me abbiamo già avuto modo di ricordarvi, il para¬ 
metro t_baud alla macro (vedi fig.3). 

A questo parametro assegnerà anche il valore de¬ 
finito con l’istruzione .set che abbiamo appena vi¬ 
sto, cioè 96. 

Poiché infine questa macro è costituita a sua vol¬ 
ta da direttive, le esegue ad una ad una. 

Nota: a questo proposito vi ricordiamo che le di¬ 
rettive sono istruzioni che vengono eseguite du¬ 
rante la fase di Compilazione (vedi rivista N.190). 

Aiutandoci con la fig.3, che riporta il file con e- 
stensione .LIS del nostro programma sorgente, ve¬ 


diamo ora come lavora il compilatore. 

A partire dalla riga 155 incontriamo: 

.ifc df set_tcr 

.warning “set_tcr già definito” 

.endc 

Questo gruppo di istruzioni equivale a: se la co¬ 
stante set_tcr è già definita, segnalami un mes¬ 
saggio di attenzione, ma prosegui ugualmente la 
compilazione generando il programma eseguibile, 
cioè il programma SERIAL.HEX. 

La direttiva .warning infatti, si utilizza per visualiz¬ 
zare il messaggio di errore non grave racchiuso 
tra virgolette. Questo messaggio apparirà sul video 
durante la fase di compilazione, fase che comun¬ 
que proseguirà per terminare normalmente. 

Il compilatore perciò controlla che set_tcr non sia 
già stato definito all’interno del programma princi¬ 
pale SERIAL.ASM. 

Come potete controllare dal listato in fig.1, nel pro¬ 
gramma SERIAL.ASM non è stata inserita nessu¬ 
na definizione di set_tcr, pertanto per il compila¬ 
tore si attiverà la condizione “non vero” e quindi 
non eseguirà la direttiva .warning, ma proseguirà 
a .endc chiudendo così questa .ifc. 

Per mostrarvi però cosa sarebbe successo nel ca¬ 
so set_tcr fosse stato definito, abbiamo provato ad 
inserire in SERIAL.ASM l’istruzione: 

set_tcr .set 30 

Abbiamo quindi lanciato di nuovo la compilazione 
il cui esito è visibile in fig.4. 

In questo caso compare a video il messaggio di 
warning con l’indicazione del file SETBAUD.LMA 
e del numero 6 che corrisponde alla riga di istru¬ 
zione della macro che ha generato il messaggio. 

Il numero [157] è invece il codice dell’errore 
deH’Assembler. 

Nota: vi ricordiamo che l’estensione .LIS è propria 
del formato listato ottenuto durante la compilazio¬ 
ne Assembler, come ampiamente spiegato nell’ar¬ 
ticolo relativo alle opzioni deH’Assembler per ST6 
pubblicato sulla rivista N.194. 

Notate comunque il messaggio *** SUCCESS *** 
che ci informa che il programma SERIAL.ASM è 
stato assemblato senza problemi. 

Viene poi visualizzato il messaggio One warning 
per ricordare che esiste comunque un problema, 
anche se non grave. 

Ma ora ritorniamo a dove eravamo rimasti e prò- 


Fig.3 LISTATO del PROGRAMMA SERIAL.LIS 


154 


116 


setbaud 

t_baud 

r 

config. velocità trasm/baud 

155 

1 

5 


. ifc 

df set_tcr 

r 




156 

1 

6 


warning 

"set_tcr già' definito" 




157 

1 

7 


endc 






158 

1 

8 


. ifc 

df set_psc 

r 




159 

1 

9 


.warning 

"set_psc già' definito" 




160 

1 

10 


. endc 






161 

1 

11 


. ifc 

eq t_baud - 12 

r 

1200 - 




162 

1 

12 

set_tcr 

. set 

140 

r 





163 

1 

13 

set_psc 

. set 

2 

r 





164 

1 

14 


.display 

"1200 BAUD" 

r 





165 

1 

15 


. else 


r 

altrimenti 




166 

1 

16 


. ifc 

eq t_baud - 24 

/ 

2400 - 


- + 


167 

1 

17 

set_tcr 

. set 

140 

r 






168 

1 

18 

set_psc 

. set 

1 

r 






169 

1 

19 


.display 

"2400 BAUD" 

/ 






170 

1 

20 


. else 


} 

altrimenti 





171 

1 

21 


. ifc 

eq t_baud - 48 

r 

4800 - 

-+ 




172 

1 

22 

set_tcr 

. set 

140 

r 


1 




173 

1 

23 

set_psc 

. set 

0 

r 


1 




174 

1 

24 


.display 

"4800 BAUD" 

r 


1 




175 

1 

25 


. else 


/ 

altrimenti 

1 




176 

1 

26 


. ifc 

eq t_baud - 96 

/ 

9600 - 

- + 1 




177 

1 

27 

set_tcr 

. set 

70 

r 


1 1 




178 

1 

28 

set_psc 

. set 

0 

/ 


1 1 




179 

1 

29 


.display 

"9600 BAUD" 

r 


1 1 




180 

1 

30 


. else 


r 

altrimenti 

1 1 




181 

1 

31 


. error 

"ERRORE SELEZ.BAUD" 

r 

ERRORE 

1 1 




182 

1 

32 


.mexit 


/ 


1 1 




183 

1 

33 


. endc 


} 


- + 1 




184 

1 

34 


. endc 


} 


-+ 




185 

1 

35 


. endc 


r 



+ 


186 

1 

36 


. endc 


} 




- + 

187 

1 

37 


. endm 


} 

fine macro 




seguiamo con le successive istruzioni, visibili sem¬ 
pre in fig.3: 

.ifc df set_psc 

.warning “set_psc già definito” 

.endc 

Questo gruppo di istruzioni equivale a: se la co¬ 
stante set_psc è già definita segnalami un mes¬ 
saggio di attenzione, ma prosegui normalmente la 
compilazione generando comunque il programma 
eseguibile. 

In questo caso, peraltro simile al precedente, è la 
costante set_psc ad essere controllata e poiché 
anche stavolta per il compilatore si attiverà la con¬ 
dizione “non vero”, non verrà eseguita la direttiva 
.warning e si proseguirà a .endc chiudendo così 
anche questa .ifc. 

Apriamo un piccola parentesi per farvi notare che, 
contrariamente agli esempi proposti all’inizio 
dell’articolo, per set_tcr e set_psc non è stata u- 


Fig.4 Messaggio di WARNING 

C:\ST6\LX1 208>ast6 -I -D -S -m serial 
ST6 MACRO-ASSEMBLERversion 4.00 - Augusti992 
Warning SETBAUD.LMA 6: [157] "set ter già definito" 
*** SUCCESS *** 

Execution lime: 0 second[s] 

One warning 


Fig.5 Messaggio di compilazione riuscita 

C:\ST6\LX1 208>ast6 -I -D -S -m serial 

ST6 MACRO-ASSEMBLER version 4.00 - Augusti 992 

9608 BAUD 

*** SUCCESS *** 

Execution time: 1 second(s] 


Fig.6 Messaggio di ERROR 

C:\ST6\LX1 208>ast6 -I -D -S -m serial 
ST6 MACRO-ASSEMBLER version 4.00 - Augusti 992 
Error SETBAUD.LMA 32: [157] "ERRORE SELEZ.BAUD" 
Execution time: 0 second(s] 

One error detected 
No object created 
























tilizzata la direttiva .else per la gestione della con- 

dizione di 

“non vero”. 

Infatti, in questi due casi ci 

interessava solo che venisse evidenziata la condi¬ 
zione “vero” delle direttive .ifc. 

Proseguiamo dunque 

con le istruzioni successive: 


.ifc 

eq t baud - 12 

set_tcr 

.set 

140 

set_psc 

.set 

2 


.display 

.else 

“1200 BAUD” 


.ifc 

eq t baud - 24 

set_tcr 

.set 

140 

set_psc 

.set 

1 


.display 

.else 

“2400 BAUD” 


.ifc 

eq t baud - 48 

set_tcr 

.set 

140 

set_psc 

.set 

0 


.display 

.else 

“4800 BAUD” 


.ifc 

eq t baud - 96 

set_tcr 

.set 

70 

set_psc 

.set 

0 


.display 

.else 

“9600 BAUD” 


.error 

.mexit 

.endc 

.endc 

.endc 

.endc 

“Errore Selez. Baud” 


Ci troviamo di fronte ad un esempio un po’ com¬ 
plesso di compilazione condizionata (.ifc) dove per 
condizione “vero” viene eseguita la direttiva .di¬ 
splay, mentre per “non vero” viene posta una nuo¬ 
va condizione .ifc, che a sua volta ha una gestio¬ 
ne per “vero” e rimanda a una nuova condizione 
di .ifc per “non vero” e così via. 


visualizzare dei messaggi a video durante la fase 
di Compilazione del programma. 

Nel nostro caso se la condizione fosse vera, a vi¬ 
deo comparirebbe “1200 BAUD”, per segnalarci 
che il programma SERIAL.ASM utilizza una velo¬ 
cità di trasmissione di 1200 baud. 

È dunque ora necessario verificare qual è il risul¬ 
tato dell’espressione t_baud - 12 e per farlo biso¬ 
gna prima ricavare il valore di t_baud. 

Se ricordate, la prima istruzione di SERIAL.ASM 
che abbiamo visto era: 

t_baud .set 96 

che assegna a t_baud il valore 96. 

Pertanto l’espressione t_baud - 12 dà come risul¬ 
tato: 

96-12 = 84. 

A questo punto è chiaro che l’istruzione diventa: 

.ifc eq 84 

e poiché l’oggetto della condizione, cioè 84, non è 
uguale a zero, si attiva la condizione di “non ve¬ 
ro”, e quindi le istruzioni: 

set_tcr .set 140 

set_psc .set 2 

.display “1200 BAUD” 

non vengono eseguite. Il compilatore passa dun¬ 
que alle istruzioni poste dopo .else: 

.ifc eq t_baud - 24 

set_tcr .set 140 

set_psc .set 1 

.display “2400 BAUD” 

.else 


Vediamo però passo passo cosa succede e ana¬ 
lizziamo la prima sequenza: 

.ifc eqt_baud-12 

set_tcr .set 140 

set_psc .set 2 

.display “1200 BAUD” 

.else 

Il compilatore confronta il valore ricavato dalla e- 
spressione t_baud - 12 con zero (condizione eq) 
e se risulta “vero” definisce la costante set_tcr e 
le associa il valore 140, inoltre definisce la costan¬ 
te set_psc e le associa il valore 2, infine esegue 
la direttiva .display. 

Quest’ultima direttiva si utilizza essenzialmente per 


e confronta nuovamente il valore ricavato dalla e- 
spressione t_baud - 24 con zero e se “vero” de¬ 
finisce la costante set_tcr e le associa il valore 140, 
definisce set_psc e le associa il valore 1, infine e- 
segue la direttiva .display. 

Siccome però l’espressione t_baud - 24 dà come 
risultato un valore non uguale a 0: 

96 - 24 = 72 

anche in questo caso viene attivata la condizione 
di “non vero”. Il compilatore ignora dunque: 

set_tcr .set 140 

set_psc .set 1 

.display “2400 BAUD” 


e passa alle istruzioni successive a .else: 

.ifc eq t_baud - 48 

set_tcr .set 140 

set_psc .set 0 

.display “4800 BAUD” 

.else 

Anche in questo caso il risultato dell’espressione 
t_baud - 48 è un valore diverso da zero: 

96 - 48 = 48 

pertanto il compilatore ignora: 

set_tcr .set 140 

set_psc .set 0 

.display “4800 BAUD” 

e passa alle istruzioni dopo .else: 

.ifc eq t_baud - 96 

set_tcr .set 70 

set_psc .set 0 

.display “9600 BAUD” 

.else 

In questo caso invece l’espressione t_baud - 96: 
96 - 96 = 0 

soddisfa la condizione per “vero” e perciò il com¬ 
pilatore esegue le istruzioni: 

set_tcr .set 70 

set_psc .set 0 

.display “9600 BAUD” 

definisce così la costante set_tcr e le associa il va¬ 
lore 70, definisce set_psc e le associa il valore 0, 
infine esegue la direttiva .display e a video com¬ 
parirà la scritta “9600 BAUD”. 

A questo punto il compilatore ignora l’istruzione .el¬ 
se e quelle che seguono: 

.error “Errore Selez. Baud” 

.mexit 

e passa alla prima delle quattro .endc che chiude 
l’ultima .ifc vista, cioè: 

.ifc eq t_baud - 96 

Poi va alla seconda .endc che chiude: 

.ifc eq t_baud - 48 


Poi va alla terza .endc che chiude: 

.ifc eq t_baud - 24 

Poi va alla quarta .endc che chiude: 

.ifc eqt_baud-12 

Per facilitarvi nella comprensione della sequenza 
logica delle istruzioni, alla destra del listato visibile 
in fig.3 abbiamo legato con dei trattini le condizio¬ 
ni .ifc alle rispettive .endc. 

Si vede così abbastanza chiaramente che si tratta 
di una serie di .ifc racchiuse una dentro l’altra, do¬ 
ve la prima del listato è l’ultima ad essere “chiusa”. 
Si parla in questo caso di .ifc “nested” che tradot¬ 
to vuol dire “nidificate”. 

Vi ricordiamo che è importantissimo “chiudere” 
sempre ogni .ifc con una .endc. 

Il compilatore segnala infatti errore nel caso che 
siano state inserite un numero maggiore o minore 
di .endc rispetto alle .ifc inserite. 

Segnala inoltre errore anche quando si inserisco¬ 
no più .else rispetto alle .ifc. 

Dopo l’ultima .endc il compilatore trova la direttiva 
.endm che gli segnala la fine della macro. 

A questo punto prosegue con la compilazione del¬ 
le rimanenti istruzioni del programma SERIAL.A- 
SM e quando arriva alla routine che predispone il 
timer per gestire la velocità di trasmissione, carica 
nel registro ter (Contatore del Timer) il valore cor¬ 
rispondente alla costante set_tcr (nel nostro e- 
sempio 70) e nel Prescaler del registro tscr il va¬ 
lore corrispondente alla costante set_psc (nel no¬ 
stro esempio 0). 

Questo permetterà di gestire i tempi strettamente 
legati alla velocità di trasmissione. 

Vi ricordiamo che trattandosi di esempi, i valori 70 
e 0 che abbiamo utilizzato sono indicativi, poiché 
quello che ci premeva farvi capire è il meccanismo 
con cui si ottengono questi valori. 

A fine compilazione comparirà a video il messag¬ 
gio visibile in fig.5. 

Notate la dicitura “9600 BAUD” visibile prima del¬ 
la scritta *** SUCCESS *** che testimonia che è 
stata selezionata la velocità di 9600 baud per la tra¬ 
smissione. 

A questo punto vi starete chiedendo cosa succede 
se nel definire t_baud, anziché utilizzare uno dei 
valori numerici gestiti dalla macro setbaud (cioè 12 
o 24 o 48 o 96) inseriamo un valore diverso, ad e- 
sempio 75. 

Aiutandovi con il listato di fig.3 che abbiamo appe¬ 
na descritto provate a simulare il compilatore. 


Tutte e quattro le espressioni che utilizzano t_baud 
danno un risultato diverso da zero; l’ultima dà ad¬ 
dirittura un risultato negativo. 

Ne consegue che verranno eseguite sempre le con¬ 
dizioni per “non vero” arrivando a: 

.error “Errore Selez. Baud” 
.mexit 


ria, non vengono eseguite in fase di esecuzione del 
programma e non generano nessuna opcode. 

A riprova di quanto detto abbiamo lanciato l’ese¬ 
cuzione del programma SERIAL.HEX tramite il si¬ 
mulatore SimST626 (presentato sulla rivista N.197) 
e come visibile in fig.7, dopo l’istruzione: 

cali init_p 


La direttiva .error viene utilizzata per fare appari¬ 
re a video la segnalazione di errore seguita, dove 
ci sia, dalla frase inserita tra virgolette. 

Quando il compilatore incontra questa direttiva, vi¬ 
sualizza il messaggio a video e continua comun¬ 
que la compilazione del programma, ma non ge¬ 
nera nessun programma eseguibile (.HEX). 
Questa direttiva si utilizza perciò per segnalare un 
caso di errore grave. 

La direttiva .mexit che abbiamo inserito di seguito 
viene utilizzata per uscire forzatamente dalla com¬ 
pilazione di una macro senza dover arrivare alla 
sua fine naturale, cioè all’istruzione .endm. 

Nella fig.6 potete vedere il messaggio che sareb¬ 
be apparso dopo la compilazione di SERIAL.ASM 
con t_baud non valido. 

Viene infatti mostrato a video il messaggio di erro¬ 
re e la dicitura finale “No object created”. 

Torniamo ora all’esempio corretto dove t_baud va¬ 
le 96 e la compilazione dà esito positivo. 
Qualcuno potrebbe obiettare che sono state inse¬ 
rite molte istruzioni, con una conseguente perdita 
di spazio e tempo di esecuzione, per ottenere la 
configurazione di due costanti: set_tcr e set_psc. 

Vorremmo però farvi osservare che se in futuro si 
presenterà la necessità di scrivere più di un pro¬ 
gramma che esegua una trasmissione e/o una ri¬ 
cezione seriale asincrona, ognuno a una diversa 
velocità di trasmissione tra le 4 proposte nella ma¬ 
cro, sarà sufficiente definire in maniera corretta il 
valore di t_baud per avere già tutto predisposto. 
Inoltre se siete dei corretti osservatori, avrete no¬ 
tato che la macro setbaud è composta esclusiva- 
mente da direttive dell’Assembler, e voi dovreste 
sapere che queste non occupano spazio di memo- 


Fig.7 Esecuzione del file SERIAL.HEX 


Jfe Assembler 


Ind. 

Codice 

Label 

Mnemonico 

OSAA 

□DDSFE 

main 

Idi 

udog,FEh 

□ 8AD 

3 ISA 


cali 

init a 

> 03AF 

4 ISA 


cali 

init p 

0BB1 

□DDSFE 

loop 

Idi 

udog,FEh 

08B4 

USA 


cali 

elabou 

□ 8B6 

2 ISA 


cali 

trasmx 

□ 8B8 

A9SA 


TP 

loop 


viene eseguita l’istruzione: 

loop Idi wdog,FEh 

e non vi è più traccia di: 

setbaud t_baud 

come invece riportato nel SERIAL.ASM di fig.2. 

Se non disponete di un simulatore, per sapere se i 
dati sono stati correttamente inseriti nel registro ter 
e nel registro tscr del Timer, vi dovete fidare di ciò 
che appare a video alla fine della compilazione e 
cioè di un messaggio simile a quello visibile in fig.5. 
Esiste però un altro controllo che si può effettuare 
quando non si dispone di un simulatore. 

È infatti sufficiente compilare il programma inse¬ 
rendo l’opzione -S per ottenere così anche il file 
con estensione .SYM. 

Come già spiegato sulla rivista N.194 relativamen¬ 
te alle opzioni del compilatore assembler, questo 
file contiene tutte le etichette e tutte le costanti u- 
tilizzate nel programma con a fianco il loro valore 
espresso in esadecimale. 

Vediamo dunque, tramite la fig.8, il listato del file 
SERIAL.SYM e andiamo a verificare i valori di: 

t_baud : EQU 00060H C 

dove appunto 60h espresso in decimale è 96. 

set_psc : EQU 00000H C 

dove il valore OOh espresso in decimale è 0. 

set_tcr : EQU 00046H C 

dove il valore 46h espresso in decimale è 70. 

SECONDO ESEMPIO 

Per il secondo esempio abbiamo realizzato una 
macro che abbiamo chiamato ritardo e che ab¬ 
biamo salvato nel file RITARDO.LMA. 

Abbiamo quindi scritto un semplice programma che 
abbiamo chiamato PROVA2.ASM e in due diversi 
punti abbiamo utilizzato la macro ritardo. 










Fig.8 LISTATO del file SERIAL.SYM 


Per ottenere un file con estensione .SYM, biso¬ 
gna compilare il programma sorgente inseren¬ 
do l’opzione -S. In questo modo si ottiene l’e¬ 
lenco delle etichette definite in Program Space 
e delle costanti simboliche utilizzate nel pro¬ 
gramma sorgente. Come potete vedere in que¬ 
ste righe, accanto a ogni etichetta (definita con 
P) o costante (definita con C), è espresso l’in¬ 
dirizzo in valore esadecimale. 


t_baud 

EQU 

00060H 

c 

ad_int 

EQU 

008a5H 

p 

init_a 

EQU 

008a3H 

p 

elabor 

EQU 

008alH 

p 

init_p 

EQU 

008a4H 

p 

inizio 

EQU 

00880H 

p 

trasmx 

EQU 

008a2H 

p 

main 

EQU 

008aaH 

p 

loop 

EQU 

008blH 

p 

nmi_int 

EQU 

008a9H 

p 

set_psc 

EQU 

00000H 

c 

set_tcr 

EQU 

00046H 

c 

tim_int 

EQU 

008a6H 

p 

A_int 

EQU 

008a8H 

p 

BC_int 

EQU 

008a7H 

p 


Fig.9 LISTATO del PROGRAMMA RITARDO.LMA 

.macro 

ritardo time,?lopl 

. if c 

ndf freqz 

. error 

"Frequenza quarzo non definita" 

.mexit 


. endc 


. if c 

gt time*freqz/6/13-256 

. error 

"Tempo troppo lungo" 

.mexit 


. endc 


. if c 

le time*freqz/6/13-1 

. error 

"Tempo troppo corto" 

.mexit 


. endc 


Idi 

carmat,time*freqz/6/13-1 

lopl dee 

carmat 

j rnz 

lopl 

. endm 



Fig.10 LISTATO del PROGRAMMA PROVA2.ASM 

carmat 

. def 

084h 

; Variabile per avere un ritardo 

freqz 

. set 
.input 

8 

"RITARDO.LMA" 

; Segnala 8MHz di frequenza 

main 


Idi 

wdog,Ofeh 

; ricarica il Watchdog 


cali 

set_pin 

; configura le porte 


cali 

e labi 

; prima elaborazione 


cali 

delayl 

; esegui un ritardo 


cali 

elab2 

/seconda elaborazione 


cali 

delay2 

/esegui un ritardo 


jP 

main 

/ripeti 

delayl 

ritardo 

ret 

1200 

/Esegue un ritardo di 1200 us 

delay2 

ritardo 

ret 

1500 

/Esegue un ritardo di 1500 us 
















In fig.9 potete vedere il listato della macro chiama¬ 
ta ritardo, mentre in fig.10 potete vedere il listato 
del programma PROVA2.ASM relativo alle sole i- 
struzioni che ci interessano ai fini dell’esempio. 

La macro riportata in fig.9 ci serve per generare un 
ritardo variabile, il cui valore andrà inserito all’in¬ 
terno del programma PROVA2.ASM in corrispon¬ 
denza delle istruzioni che richiamano questa ma¬ 
cro, cioè: 

delayl ritardo 1200 

delay2 ritardo 1500 

I valori numerici 1200 e 1500 sono i valori che ver¬ 
ranno passati dal programma sorgente alla macro 
durante la compilazione e corrispondono al ritardo 
espresso in microsecondi che verrà generato. 
Nelle istruzioni della macro è inoltre previsto un 
controllo sui valori numerici passati alla macro stes¬ 
sa, in modo che se il ritardo è minore di 10 mi¬ 
crosecondi o maggiore di 2496 microsecondi, 
venga segnalato errore. 

Una macro come quella da noi chiamata ritardo 
può risultare molto utile quando si devono inserire 
dei ritardi in determinati programmi, perché eviterà 
di dover calcolare di volta in volta il tempo dei ci¬ 
cli delle istruzioni. 

Adesso vediamo cosa avviene quando compilia¬ 
mo il programma PROVA2.ASM. 

Seguendo il listato di fig.10 troviamo subito la pri¬ 
ma istruzione: 

carmat .def 084h 

dove la variabile carmat viene associata all’area di 
Data Space 084h. Questa variabile è quella che 
verrà utilizzata dalla macro ritardo. 

La seconda istruzione: 

freqz .set 8 

definisce la costante freqz associandole il valore 8. 
Questo valore corrisponde alla frequenza di oscil¬ 
lazione del quarzo da 8 MHz utilizzato per il clock. 
E’ ovvio che se si utilizzasse un quarzo da 4 MHz, 
l’istruzione dovrebbe cambiare in: 

freqz .set 4 

La terza istruzione che incontriamo riguarda la di¬ 
rettiva .input. Come abbiamo già avuto modo di ri¬ 


cordare con il 1 “esempio, questa direttiva informa 
il compilatore che deve caricare la macro ritardo 
nel programma principale PROVA2.ASM, prele¬ 
vandola dal file RITARDO.LMA. 

Tralasciamo le istruzioni successive perché non 
strettamente inerenti all’argomento di questo arti¬ 
colo e andiamo direttamente a: 

delayl ritardo 1200 
ret 

Questa sub-routine ha il compito di effettuare un ri¬ 
tardo di 1200 microsecondi. 

Il compilatore associa l’etichetta delayl alla istru¬ 
zione ritardo 1200 e, poiché ha riconosciuto che 
ritardo è una macro, inizia a compilare le istruzioni 
contenute nella stessa macro, che, come abbiamo 
già ricordato, si trovano in fig.9. 

La prima istruzione di fig.9: 

.macro ritardo time,?lop1 

identifica la macro ritardo e informa il compilato¬ 
re che in questa macro verrà passato il parametro 
time e che verrà utilizzata l’etichetta interna ?lop1. 

Ora il compilatore prende in esame il blocco di i- 
struzioni: 

.ifc ndf freqz 

.error “frequenza quarzo non definita” 

.mexit 

.endc 

che equivale a: se la freqz del quarzo non è sta¬ 
ta definita, segnala a video un messaggio di erro¬ 
re con la scritta “Frequenza quarzo non defini¬ 
ta”, quindi esci dalla macro senza generare il pro¬ 
gramma eseguibile (istruzione .mexit). 

Poiché però nel programma sorgente freqz è sta¬ 
ta definita .set 8, questo blocco di istruzioni viene 
totalmente ignorato. 

Il compilatore passa quindi al successivo blocco di 
istruzioni: 

.ifc gt time*freqz/6/13-256 

.error “Tempo troppo lungo” 

.mexit 

.endc 

che equivale a: se il risultato dell’espressione ti- 
me*freqz/6/13-256 è maggiore (gt) di 0 allora se¬ 
gnala a video il messaggio di errore “Tempo trop¬ 
po lungo” ed esci dalla macro senza generare 


nessun programma eseguibile. 

Nota: vi ricordiamo che le espressioni sono state 
spiegate nella rivista N.189. 

Il compilatore esegue automaticamente il calcolo di 
questa espressione, ma noi possiamo verificare, 
procedendo passo passo, se la condizione è vera 
o non vera. 

Poiché time è il parametro della macro ritardo che 
viene passato nel programma PROVA2.ASM, 
quando si richiama la macro con l’istruzione: 

delayl ritardo 1200 

noi sappiamo che time equivale a 1200, quindi l’e¬ 
spressione time*freqz/6/13-256 diventa: 

1200*freqz/6/13-256 

Poiché la costante freqz è stata definita associan¬ 
dola al valore 8 del quarzo, la nostra espressione 
diventa: 

1200*8/6/13-256 

Come prima operazione eseguiamo la moltiplica¬ 
zione: 

1200*8 = 9600 

poi eseguiamo la prima divisione: 

9600/6 = 1600 

quindi la seconda divisione: 

1600/13 = 123,0769 

e infine, dopo aver scartato i decimali, eseguiamo 
l’ultima operazione con il solo numero intero: 

123-256 = -133 

Quindi l’istruzione: 

.ite gt time*freqz/6/13-256 

diventa in pratica: 

.ite gt-133 

Poiché il valore -133 non è maggiore di 0, la con¬ 
dizione posta da .ite non viene soddisfatta e quin¬ 
di il blocco di istruzioni viene ignorato e non viene 
segnalato errore. 


Il compilatore passa poi al successivo blocco di i- 
struzioni: 

.ite le time*freqz/6/13-1 

.error “Tempo troppo corto” 

.mexit 

.ende 

che equivale a: se il risultato dell’espressione ti- 
me*freqz/6/13-1 è minore o uguale (le) a 0, se¬ 
gnala a video il messaggio di errore “Tempo trop¬ 
po corto”, quindi esci dalla macro senza genera¬ 
re il programma eseguibile. 

Il compilatore esegue automaticamente il calcolo di 
questa seconda espressione, ma noi possiamo ve¬ 
rificare passo passo se questa condizione risulta 

vera o non vera. 

Poiché abbiamo già visto che time vale 1200, men¬ 
tre a freqz si associa il valore 8, l’espressione ti- 

me*f reqz/6/13-1 diventa: 

1200*8/6/13-1 

Come prima operazione eseguiamo la moltiplica¬ 
zione: 

1200*8 = 9600 

poi eseguiamo la prima divisione: 

9600/6 = 1600 

poi eseguiamo la seconda divisione: 

1600/13 = 123,0769 

e infine, dopo aver scartato i decimali, eseguiamo 
l’ultima operazione con il solo numero intero: 

123-1 =122 

Quindi l’istruzione: 

.ifc le time*freqz/6/13-1 

diventa in pratica: 

.ifc le 122 

e poiché il valore 122 è maggiore di 0, anche que¬ 
sto blocco di istruzioni verrà ignorato senza se¬ 
gnalare nessun errore, perché il valore di 1200 mi¬ 
crosecondi che vogliamo utilizzare come ritardo è 
un valore ammesso dalla macro. 


A questo punto il compilatore passa a: 

Idi carmat,time*freqz/6/13-1 

e dopo aver fatto il calcolo, che darà come risulta¬ 
to sempre 122: 

Idi carmat,122 

10 carica nella variabile carmat e lo trasforma in 
formato eseguibile. 

Continuando la compilazione trova: 

lopl dee carmat 

jrnz lopl 
.endm 

Con la direttiva .endm, il compilatore sa che la ma- 
cro ritardo è finita e torna al programma sorgente 
PROVA2.ASM per proseguire la compilazione del¬ 
le istruzioni, dove trova: 

ret 

che serve per rientrare dalla cali delayl (vedi 
fig.10). Quindi può proseguire con: 

delay2 ritardo 1500 

e riconoscendo la macro ritardo, ricompila nuova¬ 
mente le istruzioni della macro sostituendo il time 
1200 con il nuovo tempo 1500. 

Quindi l’espressione: 

.ite gt time*freqz/6/13-256 

viene semplificata in: 

1500*8/6/13-256 

11 cui risultato è: 

1500*8 = 12000 
12000/6 = 2000 
2000/13 = 153 
153-256 =-103 

L’istruzione diventa pertanto: 

.ite gt-103 

Poiché il valore -103 non è maggiore di 0, questo 
blocco di istruzioni viene ignorato e non viene se¬ 
gnalato nessun errore. 

Il compilatore passa poi al secondo blocco di i¬ 


struzioni, dove l’espressione: 

.ite le time*freqz/6/13-1 

viene semplificata in: 

1500*8/6/13-1 

il cui risultato è: 

1500*8 = 12000 
12000/6 = 2000 
2000/13 = 153 
153-1 =152 

L’istruzione diventa pertanto: 

.ite le 152 

e poiché il valore 152 è maggiore di 0 anche que¬ 
sto blocco di istruzioni verrà ignorato senza se¬ 
gnalare nessun errore, perché il valore di 1500 mi¬ 
crosecondi che vogliamo utilizzare come ritardo è 
un valore ammesso dalla macro. 

A questo punto il compilatore passa a: 

Idi carmat,time*f reqz/6/13-1 

e dopo aver fatto il calcolo, che da come risultato 
sempre 152: 

Idi carmat,152 

lo carica nella variabile carmat e lo trasforma in 
formato eseguibile. 

Continuando la compilazione trova: 

lopl dee carmat 

jrnz lopl 

.endm 

Con la direttiva .endm il compilatore sa che la ma¬ 
cro ritardo è finita e torna al programma sorgente 
PROVA2.ASM per proseguire la compilazione del¬ 
le istruzioni, dove trova: 

ret 

che serve per rientrare dalla cali delay2 (vedi 
fig.10). 

Ora proviamo a simulare il programma ottenuto con 
la compilazione, cioè PROVA2.HEX, e in fig.11 ve¬ 
diamo la parte relativa al nostro esempio. 

Osservate le righe evidenziate in giallo che si rife- 


riscono alla sub-routine delayl ricavata dalla ma- 

cro ritardo: 


delayl 

Idi 

carmat,7Ah 

L0$ 

dee 

carmat 


jrnz 

L0$ 


ret 



Trasformando il valore esadecimale 7Ah nel suo 
decimale corrispondente, otteniamo 122, che, co¬ 
me desiderato, ci permetterà di ottenere un ritardo 

di 1200 microsecondi. 

Le righe evidenziate in verde si riferiscono invece 
alla sub-routine delay2 ricavata sempre dalla ma- 

cro ritardo: 


delay2 

Idi 

carmat,98h 

LI $ 

dee 

carmat 


jrnz 

L1$ 


ret 



Trasformando il valore esadecimale 98h nel suo 
decimale corrispondente, otteniamo 152, che, co¬ 
me desiderato, ci permetterà di ottenere un ritardo 

di 1500 microsecondi. 

Prima però di verificare se effettivamente si otten¬ 
gono i ritardi voluti, apriamo una parentesi per ri¬ 
cordarvi che, quando il compilatore, come nel no¬ 
stro caso, incontra nelle macro delle etichette o la- 
bels interne (?lop1 in fig.9) le genera automatica- 
mente nel file .HEX assegnandole un numero con¬ 
secutivo. Ecco perché le istruzioni della macro: 

lopl dee carmat 

jrnz lopl 

nella simulazione del programma sono diventate ri¬ 
spettivamente: 


L0$ 

dee 

carmat 


jrnz 

L0$ 

L1$ 

dee 

carmat 


jrnz 

L1$ 


Chiudiamo la parentesi e andiamo a fare un pic¬ 
colo controllo per verificare se effettivamente ven¬ 
gono ottenuti i ritardi voluti. 

Sommiamo dunque i cicli delle istruzioni delle due 
sub-routine e moltiplichiamo il risultato per il tem¬ 
po di un ciclo macchina che corrisponde a 1,625 
microsecondi. 

Nell’articolo relativo al software simulatore per te¬ 
stare i micro ST6 pubblicato sulla rivista N.185, ab¬ 
biamo fornito l’elenco completo delle istruzioni As¬ 
sembler indicando, tra le altre cose, il numero dei 
cicli macchina. 



Per un ritardo di 1200 abbiamo: 



cali 

delayl 

1x4 cicli = 4 

delayl 

Idi 

carmat,7Ah 

1x4 cicli = 4 

L0$ 

dee 

carmat 

122 x 4 cicli = 488 


jrnz 

L0$ 

122 x 2 cicli = 244 


ret 


1x2 cicli = 2 


Sommando i cicli macchina di queste sub-routine 
otteniamo 742. 

Poiché un ciclo macchina corrisponde a 1,625 mi¬ 
crosecondi noi otteniamo un effettivo ritardo di: 

742 x 1,625 = 1205,75 microsecondi 

La differenza di 5,75 microsecondi in più rispetto 
al ritardo impostato nel file sorgente non è un er¬ 
rore, ma, in questo caso, è dovuto al necessario 
arrotondamento operato sui decimali nell’espres¬ 
sione calcolata. 

Per un ritardo di 1500 abbiamo: 



cali 

delay2 

1x4 cicli = 4 

delay2 

Idi 

carmat,98h 

1x4 cicli = 4 

L1$ 

dee 

carmat 

152 x 4 cicli = 608 


jrnz 

L1$ 

152 x 2 cicli = 304 


ret 


1x2 cicli = 2 


Sommando i cicli macchina di queste sub-routine 
otteniamo 922. 

Poiché un ciclo macchina corrisponde a 1,625 mi¬ 
crosecondi noi otteniamo un effettivo ritardo di: 

922 x 1,625 = 1498,25 microsecondi 

La differenza di 1,75 microsecondi in meno ri¬ 
spetto al ritardo impostato nel file sorgente non è 
un errore, ma, in questo caso, è dovuto al neces¬ 
sario arrotondamento operato sui decimali nell’e¬ 
spressione calcolata. 













IL programma LINKER 


Con l’articolo sul linker LST6 di cui ci occupiamo in queste pagine, pro¬ 
seguiamo l’esposizione dei diversi aspetti della programmazione dei mi¬ 
crocontrollori della serie ST6. Non vi nascondiamo che l’argomento non 
è dei più semplici, ma con l’aiuto di qualche esempio, siamo certi che 
anche questa materia non avrà più segreti. 


Fino ad oggi nella realizzazione di un programma 
in Assembler per i micro ST6 ci siamo sempre po¬ 
sti l’obiettivo di scrivere un programma sorgente, 
cioè un file in formato .ASM dal quale ottenere un 
file in formato eseguibile .HEX. 

Infatti, in tutti gli articoli pubblicati e nei diversi e- 
sempi di programmi che vi abbiamo fornito, abbia¬ 
mo sempre pensato al programma come a una co¬ 
sa unica, a sé stante, risultato della compilazione 
in Assembler di un unico file sorgente con tutt’al 
più l'inserimento, tramite la direttiva .input, di su¬ 
broutine, macro o definizioni di variabili esterne, ma 
sempre in formato sorgente. 

L’articolo di oggi si propone invece di illustrarvi un 
secondo metodo per la realizzazione dei vostri pro¬ 
grammi, non necessariamente migliore dell’altro, 
ma sicuramente differente perché presuppone il 
conseguimento di un altro scopo. 


Con il linker, termine che possiamo rendere in i- 
taliano con programma di collegamento, si può 
ottenere un programma finale eseguibile .HEX sen¬ 
za avere il corrispondente programma in formato 
sorgente, ma collegando programmi diversi as¬ 
semblati in formato oggetto .OBJ. 

Per semplicità possiamo dunque definire il linker 
come un programma che concatena moduli softwa¬ 
re al fine di realizzare un programma eseguibile 
completo. 

Il primo passo per usare il linker è quello di disporre 
di una serie di programmi assemblati singolarmen¬ 
te in formato oggetto .OBJ utilizzando le opportune 
opzioni del programma compilatore Ast6. 

Il secondo passo è quello di lanciare il programma 
Lst6 di linkaggio dei file .OBJ con le opportune op¬ 
zioni, in modo da ottenere il programma definitivo 
eseguibile in formato .HEX. 




































































I PROGRAMMI in formato .HEX 

Sulla base di quanto fin qui detto, qualcuno po¬ 
trebbe domandarsi perché non usare il linker di¬ 
rettamente con i programmi in formato .HEX, inve¬ 
ce di utilizzare dei programmi in formato .OBJ. 

Quando si lancia la compilazione Assembler di un 
programma, ad esempio PIPPO.ASM, a compila¬ 
zione conclusa, se non vi sono errori, si genera un 
programma in formato Intel eseguibile, nel nostro 
caso PIPPO.HEX. 

Nel file in formato .HEX, le singole istruzioni del 
programma sorgente .ASM, sono tradotte in codi¬ 
ce binario direttamente eseguibile e soprattutto vi 
è una corrispondenza diretta tra le locazioni di 
memoria, sia RAM che ROM, attribuite durante la 
stesura del programma sorgente e quelle ottenute 
dalla compilazione dell’eseguibile .HEX. 


I PROGRAMMI in formato .OBJ 

I programmi in formato oggetto .OBJ si ottengono 
utilizzando l’opzione -O quando si lancia la com¬ 
pilazione di un programma. 

Ad esempio, se compiliamo il file sorgente PIP¬ 
PO.ASM con le opzioni: 

Ast6 -L -O PIPPO.ASM 

otteniamo il programma PIPPO.OBJ. 

Nota: ricordiamo ai lettori che le opzioni del com¬ 
pilatore Assembler e il loro utilizzo sono state am¬ 
piamente trattate nella rivista N.194. 

II programma generato in formato .OBJ ha due ca¬ 
ratteristiche: 

1 - non è direttamente eseguibile, pertanto non 
può essere simulato né caricato su un micro. 


per i microprocessori ST6 


Infatti, all’interno di ogni programma, dopo la defi¬ 
nizione dei registri e della variabili, viene posta la 
direttiva .org 0800h o 0880h che serve a posizio¬ 
nare in maniera assoluta le istruzioni da quell’in- 
dirizzo di memoria ROM in poi. 

La stessa cosa si ottiene alla fine con la direttiva 
.org OFFOh, che posiziona le eventuali gestioni dei 
vettori di interrupt da quell’indirizzo di memoria as¬ 
soluta in poi. 

Comprenderete quindi che se si tentasse di “unire” 
tramite il linker parti di più programmi in formato 
.HEX, essendo ognuna di esse posizionata a un in¬ 
dirizzo fisso di memoria, si dovrebbe realizzare un 
programma ad incastro, in maniera che la routine 
che ci interessa inserire dopo le istruzioni del pro¬ 
gramma principale iniziasse esattamente ad una 
ben precisa locazione di memoria successiva a 
quella già occupata, in caso contrario si correrebbe 
il rischio di “sovrascrivere” porzioni di programma. 
Unire moduli software diventerebbe così un lavoro 
estremamente difficile, se non impossibile. 

A facilitare il nostro compito, ci viene in aiuto il for¬ 
mato .OBJ, che essendo rilocabile e non ese¬ 
guibile, meglio si presta ad essere linkato. 
Vediamo dunque cosa sono i programmi in forma¬ 
to .OBJ e come ottenerli. 


2 - le istruzioni contenute non sono in formato as¬ 
soluto, bensì in formato “rilocabile”. 

In altre parole le istruzioni hanno un indirizzamen¬ 
to di memoria e di Program Counter relativo (e non 
assoluto come nel formato .HEX) e quindi posso¬ 
no essere “ricollocate” o, utilizzando un termine 
specifico, rilocate. 

E’ dunque utile chiarire cosa si intende per indiriz¬ 
zamento relativo e indirizzamento assoluto. 

Pensate ad esempio alla numerazione delle pagi¬ 
ne di un libro qualsiasi o di una rivista. 

Ogni numero specifica la posizione della pagina ri¬ 
spetto alle altre, per cui il numero 10 specifica che 
quella pagina è la decima della rivista, il numero 
128 specifica che quella pagina è la centoventot- 
tesima della rivista, e così via. 

In questo caso si può parlare di indirizzamento 
assoluto e, a patto di non intervenire in maniera 
cruenta con tagli o strappi, questo indirizzamento 
non cambierà mai. 

Se però decidete di raccogliere insieme gli articoli 
riguardanti un unico argomento, la numerazione 
delle pagine non sarà più consecutiva, cioè non a- 
vrà una progressione numerica, ma sarà relativa 
alla rivista dalla quale proveniva l’articolo. 



Solo quando “concatenerete” uno all’altro gli arti¬ 
coli rinumerando le pagine, darete un nuovo indi¬ 
rizzamento assoluto alla vostra raccolta. 


LISTATO del programma CONTA.ASM 


Chiusa questa parentesi, torniamo ai programmi 
.OBJ per precisare che non basta inserire l’opzio¬ 
ne -O nella compilazione Assembler per ottenere 
questo formato. 

Se provate a compilare un vostro programma in¬ 
serendo questa opzione, vedrete che il compilato¬ 
re vi segnalerà un certo numero di errori. 

Proprio per le sue peculiarità, nei programmi sor¬ 
gente bisogna inserire alcune precise direttive e 
modificarne o toglierne altre prima di generare il 
formato .OBJ. 

Le direttive specifiche che servono per generare il 
formato oggetto e quindi anche per linkare i pro¬ 
grammi .OBJ, sono: 


.pp_on 

.extern 

.section 

.window 

.windowend 

.global 

.notransmit 

.transmit 

Nell’esempio che vi proponiamo di seguito cerche¬ 
remo di chiarire in quale modo e perché vanno u- 
tilizzate queste direttive per ottenere un program¬ 
ma .OBJ senza errori. 

I programmi PLEXER.ASM e PCONT.ASM 

Per il nostro esempio abbiamo utilizzato un nostro 
datato, ma semplice programma dimostrativo che 
esegue un conteggio e lo visualizza su due display. 
In fig.1 abbiamo riportato il listato del programma 
CONTA.ASM così come lo avevamo realizzato. 

Dal programma CONTA.ASM abbiamo estratto le 
istruzioni che vedete evidenziate in azzurro in fig.1 
e le abbiamo inserite in un nuovo programma che 
abbiamo chiamato PLEXER.ASM. 

Questo programma ci mette a disposizione una se¬ 
rie di subroutine che gestiscono l’incremento o il 
decremento di un contatore e la visualizzazione a 
due cifre del risultato su 2 display in multiplexer. 

Abbiamo quindi cancellato dal programma CON¬ 
TA.ASM le istruzioni inserite in PLEXER.ASM e 
abbiamo salvato ciò che rimaneva con il nome 
PCONT.ASM per non confonderlo con l’originale. 


; * Programma per fare un conteggio * 


.title 
. vers 
. w_on 
.romsize 
.input 


"CONTA" 

"ST62E25" 

4 

"ST62X.DEF" 


; VARIABILI usate da questo PROGRAMMA 


lsb 

.def 

084h 

msb 

.def 

085h 

dell 

.def 

086h 

del2 

.def 

087h 

up_dw 

.def 

088h 


. org 

0800h 

inizio 

Idi 

wdog,Offh 


Idi 

port_a,0000000 Ob 


Idi 

pdir_a,OOOOllOOb 


Idi 

popt_a,OOOOllOOb 


Idi 

port_b,OOOOOOOOb 


Idi 

pdir_b,llllllllb 


Idi 

popt_b,llllllllb 


Idi 

port_c,OOOOOOOOb 


Idi 

pdir_c,OOOOOOOOb 


Idi 

popt_c,OOOOOOOOb 

• *** 
r 

Disabilita 

gli Interrupt 


Idi 

adcr,0 


Idi 

tscr,0 


Idi 

ior f 0 


reti 



jP 

main 


GESTORI di INTERRUPT 


ad_int reti 
tim_int reti 
BC_int reti 
A_int reti 
nmi_int reti 


Fig.1 Dal programma CONTA.ASM, di cui vi 
forniamo il listato, abbiamo estratto le i- 
struzioni evidenziate in azzurro e le abbia¬ 
mo salvate nel file PLEXER.ASM (vedi fig.3). 
Le istruzioni rimaste sono state salvate nel 
file PCONT.ASM (vedi fig.2). 









. *** 

I 


SUBROUTINE *** 


• *** 
r 

PROGRAMMA PRINCIPALE *** 

;- multiplexa 

le 

2 cifre sui display 


main 



mulplx 






Idi 

wdog,Ofeh 


ld 


a, lsb 






addi 


a,40h 



Idi 

lsb, 0 


ld 


x, a 



Idi 

msb, 0 


ld 


a, (x) 



Idi 

up_dw, 1 


Idi 


port_a,OOOOllOOb 






ld 


port_b,a 



Idi 

drw, digit. w 


Idi 


port_a,OOOOOlOOb 










loop 

Idi 

dell,17 


ld 


a, msb 


maini 

Idi 

del2,255 


addi 


a, 40h 


main2 

Idi 

wdog,Ofeh 


ld 


x, a 






ld 


a, (x) 



cali 

mulplx 


Idi 


port_a,OOOOllOOb 






ld 


port_b,a 



dee 

del2 


Idi 


port_a,OOOOlOOOb 



jrz 

main3 







jP 

main2 


ret 




main3 

dee 

dell 







jrz 

main6 

;- incremento 

delle 2 cifre 





; - con 

controlli 




jrs 

0,port_a,main4 

increm 






Idi 

up_dw,0 


ine 


lsb 


ma in 4 

jrs 

1,port_a,main5 


ld 


a, lsb 



Idi 

up_dw,1 


cpi 


a, 10 


main5 




jrnz 


inerì 



jP 

maini 


Idi 


lsb, 0 


main 6 




ine 


msb 



ld 

a,up_dw 


ld 


a, msb 



cpi 

a, 0 


cpi 


a, 10 



jrz 

main7 


jrnz 


inerì 






Idi 


msb, 0 



cali 

increm 

inerì 






jP 

loop 


ret 












main7 

cali 

decrem 

; - decremento 

delle 2 cifre 



jP 

loop 

; - con 

controlli 






decrem 





• *** 
r 

tabella con ì segmenti per far 


ld 


a, lsb 


; apparire sui 

display le cifre *** 


cpi 

jrnz 


a, 0 
de cri 



.block 

64-$%64 ■ 


Idi 


lsb, 9 


digit 

. byte 

192,249,164,176,153 







.byte 

146,130,248,128,144 


ld 


a, msb 


• *** 

VETTORI DI 

INTERRUPTS *** 


cpi 


a, 0 






jrnz 


decr2 






Idi 


msb, 9 



. org 

Off Oh 


ret 





jP 

ad_int 







jP 

tim_int 

decr2 

dee 


msb 



jP 

BC_int 


ret 





jP 

A int 







. org 

Off eh 

de cri 

dee 


lsb 



jP 

nmi_int 


ret 





jP 

inizio 







. end 












LISTATO del programma PCONT.ASM 


; * Programma per fare un conteggio * 



.title 

. vers 

. w_on 

.romsize 

"PCONT" 

"ST62E25" 

4 

•PP on 


.input 

"ST62X.DEF" 

;VARIABILI usate 

da questo PROGRAMMA 

dell 

.def 

084h 

del2 

.def 

085h 

up_dw 

.def 

086h 

lsb 

.def 

087h 

msb 

.def 

088h 


.extern decrem,increm,mulplx 


.section 

1 

inizio 




Idi 

wdog,Offh 


Idi 

port_a,0000000Ob 


Idi 

pdir_a,OOOOllOOb 


Idi 

popt_a,OOOOllOOb 


Idi 

port_b, OOOOOOOOb 


Idi 

pdir_b,1111111 lb 


Idi 

popt_b,1111111lb 


Idi 

port_c, OOOOOOOOb 


Idi 

pdir_c, OOOOOOOOb 


Idi 

popt_c, OOOOOOOOb 

;*** Disabilita 

gli Interrupt 


Idi 

adcr,0 


Idi 

tscr,0 


Idi 

ior, 0 


reti 



jP 

main 

• *** 
r 

GESTORI di INTERRUPT *** 

ad_int 

reti 


tim_int 

reti 


BC_int 

reti 


A_int 

reti 


nmi_int 

reti 


Fig.2 Listato del programma PCONT.ASM. 


Per compilarlo in formato oggetto .OBJ ab¬ 
biamo dovuto inserire le direttive eviden¬ 
ziate in giallo. 


• *** 
t 

PROGRAMMA PRINCIPALE 

*** 

main 

Idi 

wdog,Ofeh 



Idi 

lsb, 0 



Idi 

msb, 0 



Idi 

up_dw,1 



Idi 

drw,digit. w 


loop 

Idi 

dell,17 


maini 

Idi 

del2,255 


main2 

Idi 

wdog,Ofeh 



cali 

mulplx 



dee 

del2 



jrz 

main3 



jP 

main2 


main3 

dee 

dell 



jrz 

main6 



jrs 

0,port_a,main4 



Idi 

up_dw,0 


main4 

jrs 

1,port_a,main5 



Idi 

up_dw,1 


main5 

jP 

maini 


main6 

ld 

a,up_dw 



cpi 

a, 0 



jrz 

main7 



cali 

increm 



jP 

loop 


main7 

cali 

decrem 



jP 

loop 


• *** 

tabella 

con i segmenti per 

far 

; apparire sui display le cifre 

*** 


.window 


digit 

.byte 

192,249,164,176,153 


.byte 

146,130,248,128,144 


.windowend 


;*** VETTORI DI 

INTERRUPTS *** 

.section 


jP 

ad_int 

jP 

tim_int 

jP 

BC_int 

jP 

A int 

.block 

4 

jP 

nmi_int 

jP 

inizio 


. end 






















A questo punto abbiamo due programmi, 
PLEXER.ASM e PCONT.ASM, che dobbiamo mo¬ 
dificare e compilare separatamente per ottenere ri¬ 
spettivamente PCONT.OBJ e PLEXER.OBJ. 

Vedremo così come, linkando questi programmi, si 
ottenga un terzo programma in formato .HEX. 

Per generare in formato .OBJ il programma 
PCONT, abbiamo dovuto modificare il listato come 
visibile in fig.2. Per generare in formato .OBJ il pro¬ 
gramma PLEXER, abbiamo dovuto modificare il li¬ 
stato come visibile in fig.3. 

In entrambe le figure abbiamo evidenziato in gial¬ 
lo le direttive inserite e ora analizzeremo nei det¬ 
tagli queste modifiche via via che le incontreremo. 


La direttiva .pp_on 

Rispetto al programma originario, e cioè CON- 
TA.ASM, nel programma PCONT.ASM dopo la di¬ 
rettiva .romsize 4 abbiamo inserito la direttiva 
.pp_on, che abilita la paginazione della memoria 
del micro. 

Normalmente questa direttiva va inserita quando si 
realizzano programmi per i microprocessori ST6 
che dispongono di più di 4 kbyte di memoria Pro¬ 
gram Space (ROM). 

In questi modelli di micro infatti, esiste una memo¬ 
ria ROM che possiamo definire primaria di 4096 













PAGINE ROM SOVRAPPOSTE 



Fig.4 I micro con più di 4 kbytes di memo¬ 
ria Program Space hanno una ROM prima¬ 
ria suddivisa in tre pagine di grandezza di¬ 
versa: da OOOOh a 07FFh, da 0800h a OFEFh 
e da OFFOh a OFFFh. Inoltre hanno un mas¬ 
simo di 30 pagine sovrapposte con loca¬ 
zione da OOOOh a 07FFh. 


bytes che va da locazione OOOOh a OFFFh e un 
massimo di 30 “pagine” sovrapposte di 2048 bytes 
di area ROM, tutte con locazione da OOOOh a 
07FFh, come visibile nel disegno di fig.4. 

La stessa memoria primaria viene ulteriormente 
suddivisa in tre pagine di area ROM di grandezza 
diversa: la prima ha locazione OOOOh - 07FFh, la 
seconda ha locazione 0800h - OFEFh e la terza ha 
locazione OFFOh - OFFFh. 

A ciascuna per comodità viene virtualmente asso¬ 
ciato un numero di pagina che va da 0 a 32 (vedi 
tabella di fig.5) e ogni pagina deve essere indiriz¬ 
zata tramite un’altra direttiva chiamata .section. 
Utilizzando .pp_on, e quindi segnalando al compi¬ 
latore che deve virtualmente suddividere la memo¬ 
ria in pagine, bisognerà utilizzare anche la direttiva 
.section che serve a indirizzare queste pagine. 

Nel nostro esempio noi utilizziamo un micro 
ST62E25 che non supera i 4 kbyte di memoria (ve¬ 
di .vers in fig.2), ma volendo generare un program¬ 
ma in formato .OBJ siamo obbligati ad inserire la di¬ 


rettiva .section e, di conseguenza, a definire anche 
.pp_on, altrimenti il compilatore segnalerà errore. 

La direttiva .extern 

Sempre rispetto al programma CONTA, la suc¬ 
cessiva istruzione che abbiamo inserito nel pro¬ 
gramma PCONT è la direttiva .extern con a fian¬ 
co l’indicazione di tre etichette: 

.extern decrem,increm,mulplx 

La direttiva .extern va obbligatoriamente inserita o- 
gniqualvolta si intende assemblare in formato .OBJ 
un programma contenente istruzioni che richiama¬ 
no o saltano a labels di routine che non si trovano 
all’interno del programma stesso, ma sono inseri¬ 
te in altri programmi. In questo modo si avverte il 
compilatore di non segnalare errore quando non 
trova le routine richiamate. 

Nel programma PCONT (vedi listato in fig.2) ci so¬ 
no infatti tre routine chiamate con le istruzioni: 

cali mulplx 
cali increm 
cali decrem 

che non vengono assolutamente definite, perché 
inserite nel programma PLEXER (vedi fig.3). 

Inserendo la direttiva .extern, abbiamo avvertito il 
compilatore che le routine sono esterne, e che 
quindi non deve segnalare errore quando incontra 
le istruzioni che le richiamano. 

Per avere una riprova di ciò, abbiamo provato a to¬ 
gliere l’istruzione: 

.extern decrem,increm,mulplx 

e abbiamo compilato PCONT. 

In fig.6 è visibile la segnalazione di errore del com¬ 
pilatore, in cui queste tre etichette vengono indica¬ 
te come “undefined symboi”. 

E’ importante annotare che quando si utilizza que¬ 
sta direttiva per definire labels di routine esterne 
al programma, conviene sempre porla all’inizio co¬ 
sì da rendere visibile già in fase di edit, che il pro¬ 
gramma contiene salti o richiami a routine esterne. 

Possono essere definite come .extern solamente 
labels di Program Space e di Data Rom Windows. 

Non possono essere definite come .extern i regi¬ 
stri, le variabili di Data space o le costanti (.def, 
.equ, .set). 

















Pagina N° INDIRIZZO VIRTUALE INDIRIZZO REALE 


0 

0000 - 07FF 

0000 - 07FF 

1 

0800 - 0FEF 

0800 - 0FEF 

2 

1000-UFF 

0000 - 07FF 

3 

1800- 1FFF 

0000 - 07FF 

da 4 a 31 

[n*800]-[(9n*80)+7FF] 

0000 - 07FF 

32 

0FF0 - 0FFF 

0FF0 - 0FFF 


Fig.5 A ogni pagina di memo¬ 
ria, che ha un suo preciso in¬ 
dirizzo reale, viene associato 
per comodità un indirizzo vir¬ 
tuale rappresentato da un nu¬ 
mero da 0 a 32. 


Per finire, questa direttiva può essere inserita so¬ 
lamente nei programmi che verranno compilati con 
l’opzione -O. In caso contrario il compilatore se¬ 
gnalerà errore. 

La direttiva .section 

Confrontate ancora il programma PCONT.ASM di 
fig.2 all’altezza della label inizio con il programma 
CONTA.ASM di fig.1 alla stessa altezza. 

Nel programma originale CONTA.ASM prima del¬ 
la label inizio avevamo inserito l’istruzione .org 
0800h, mentre in PCONT.ASM l’abbiamo sostitui¬ 
ta con .section 1. 

Quando si assembla un programma in formato 
.OBJ si deve sostituire la direttiva .org con la di¬ 
rettiva .section seguita da un numero da 0 a 32, 
altrimenti verrà segnalato errore. 

In relazione a quanto detto precedentemente a pro¬ 
posito della direttiva .pp_on, che attiva la “pagina¬ 
zione” o, se preferite, la suddivisione in pagine del¬ 
la memoria ROM, inserendo nel programma la di¬ 
rettiva .section noi indichiamo al compilatore in qua¬ 
le “pagina” di memoria ROM deve inserire le istru¬ 
zioni del programma da compilare in formato .OBJ. 


Nel nostro caso, noi indichiamo al compilatore che 
le istruzioni del programma PCONT devono esse¬ 
re inserite nella Program Space di pagina 1, e cioè 
nell’area ROM con locazione 0800h - OFEFh co¬ 
me visibile in fig.7. 

AlPinterno dello stesso programma è possibile in¬ 
serire più direttive .section per indirizzare pagine 
diverse ed inserire perciò le istruzioni in punti di¬ 
versi di Program Space. 

Poiché però vi sono alcune limitazioni sull’utilizzo 
delle istruzioni di salto da una pagina di memoria 
all’altra, bisogna fare attenzione alle caratteristiche 
di “salto" legate al numero di pagina utilizzato. 

In fig.7 riportiamo la tabella illustrativa di queste li¬ 
mitazioni. 

Nella colonna “salto a...”, in corrispondenza delle 
righe di pagina 1 e di pagina 32 è indicato tutte le 
pagine, mentre nelle restanti è indicato pagina 1. 
Questo significa che nelle pagine 1 e 32 di Pro¬ 
gram Space si possono inserire istruzioni di salto 
incondizionato (jp, cali) a tutte le altre pagine di 
memoria, mentre nelle pagine 0 e da 2 a 31 si pos¬ 
sono inserire solamente istruzioni di salto incondi¬ 
zionato alla pagina 1. 


C: \ST6\LX1 208>ast6 -1 -o PCONT.ASM 
ST6 MACRO-ASSEMBLER uersion 4.00 - August 1992 

Error PCONT.ASM 94: (108) undefined symbol: decrem 

Error PCONT.ASM 91: (106) undefined symbol: increm 

Error PCONT.ASM 72: (106) undefined symbol: mulplx 


Error PCONT.ASM 91 : (106) 
Error PCONT.ASM 72: (106) 
Exeoution time: 0 second(s) 
3 errors detected 
No object created 


Fig.6 Errore segna¬ 
lato dal compilatore 
quando non si usa 
correttamente la di¬ 
rettiva .extern. 





















Pagina N° INDIRIZZO VIRTUALE INDIRIZZO REALE SALTO A 


0 

0000 - 07FF 

0000 - 07FF 

Pagina 1 

1 

0800 - 0FEF 

0800 - 0FEF 

tutte le Pag. 

2 

1000-UFF 

0000 - 07FF 

Pagina 1 

3 

1800-1FFF 

0000 - 07FF 

Pagina 1 

da 4 a 31 

[n*800]-[(9n*80)+7FF] 

0000 - 07FF 

Pagina 1 

32 

0FF0 - 0FFF 

0FF0 - 0FFF 

tutte le Pag. 


Fig.7 Esistono delle limitazio¬ 
ni suN’utilizzo dell’istruzione 
di salto da una pagina di me¬ 
moria all’altra, per cui nelle 
pagine 0 e da 2 a 31 si posso¬ 
no inserire solo istruzioni di 
salto a pagina 1. 


Facciamo un esempio. Compilando il programma: 

.section 1 
inizio . 


jp letsta 
rienl . 


.section 2 
letsta Idi a,23 


cali storx 


.section 3 
storx addi a,23 


ret 

non verrà segnalato errore, perché le istruzioni so¬ 
no formalmente corrette. 

Quando però tenteremo di linkare questo pro¬ 
gramma, il linker segnalerà un errore simile a quel¬ 
lo di fig.8, perché non sono state rispettate le con¬ 
dizioni. Infatti, da pagina 1 con l’istruzione jp let¬ 
sta si può passare alla pagina 2, ma poi l’istruzio¬ 
ne cali storx non può essere eseguita perché 
storx si trova nella pagina 3. 


La giusta sequenza del nostro esempio è dunque 
la seguente: 

.section 1 
inizio . 


jp letsta 

rienl cali storx 


.section 3 
letsta Idi a,23 


jp rienl 
.section 4 
storx addi a,23 


ret 

L’esempio appena riportato si riferiva a più section 
inserite in un unico programma, ma è evidente che 
si pone un problema analogo quando diverse .sec¬ 
tion sono inserite in più programmi che andranno 
concatenati con il linker. 

Chiusa questa parentesi, torniamo al listato di 
PCONT (vedi fig.2) e soffermiamoci sull’istruzione 

.section 32 e sulla successiva .block 4. 


reference to <increm> external 
reference to <mulplx> external 

ls16: illegal jump inside program section tt2, offset 0x0, file <PC0NT.0BJ> 


Fig.8 II controllo sul rispetto delle condizioni necessarie all’esecuzione dell’istruzione di 
salto viene fatto dal programma linker Lst6. In questa figura è segnalato errore perché l’i¬ 
struzione di salto da pagina 2 può essere eseguita solo verso pagina 1 (vedi fig.7), e non 
a pagina 3 come scritto nel programma a sinistra sopra questa figura. 





































Nelle stesse righe del programma originale CON- 
TA.ASM vi erano le istruzioni .org OFFOh e .org 
OFFCh 

Con .section 32 si attiva la pagina di memoria re¬ 
lativa alla gestione dei vettori di reset e di interrupt. 
La direttiva .block 4 sostituisce .org OFFCh, ma 
ha la stessa funzione di posizionare correttamente 
i vettori di nmi e di reset. 

Le direttive .window e .windowend 

Mettendo ancora una volta a confronto le righe del 
programma originale CONTA con quelle di 
PCONT, potete vedere che l’istruzione: 

.block 64-$%64 

è stata sostituita dalla direttiva .window, mentre 
dopo il secondo .byte è stata inserita la direttiva 

.windowend. 

Come abbiamo avuto occasione di ripetere più vol¬ 
te (vedi soprattutto la rivista N.190), normalmente 
l’istruzione .block 64-$%64 precede l’inserimento 
di dati in Program Space (.byte, .ascii, .asciz) che 
verranno caricati a blocchi di 64 bytes tramite la 
Data Rom Windows. 


PROGRAM 

SECTIONS 


number 

start 

end size 

1 

0300 

0F9F 00D3 

32 

0FF0 

OFFF 0010 

MODULE 

PCONT.OBJ 


section 

type 

start size 

1 

P 

0300 008A 

32 

P 

0FF0 0010 

MODULE 

PLEXER.OBJ: 

section 

type 

start size 

1 

P 

OSSA 0043 


Fig.9 Mappa della memoria risultante dal 
link ottenuto con PCONT.OBJ e 
PLEXER.OBJ. Non avendo inserito le diret¬ 
tive .window e .windowend i due program¬ 
mi sono stati accodati. 


Compito principale di .block 64-$%64 è di “otti¬ 
mizzare” l’utilizzo di Program Space. 

Compilando il programma PCONT in formato .OBJ 
avremmo anche potuto lasciare l’istruzione .block 
64-$%64, però i dati definiti con le due direttive .by¬ 
te sarebbero stati allocati con allineamento al pri¬ 
mo blocco di 64 byte di Program Space succes¬ 
sivo all’ultima istruzione di PCONT e cioè jp loop. 
Linkando i due programmi PCONT.OBJ e 
PLEXER.OBJ, il linker avrebbe “accodato” al pro¬ 
gramma PCONT le istruzioni del programma 
PLEXER, che quindi si sarebbero venute a trova¬ 
re dietro a quest’area dati. 

Avremmo pertanto avuto un programma finale 
.HEX non bene ottimizzato, sia come utilizzo di 
memoria Program Space sia come “leggibilità”. 

Per provarvi quanto detto, abbiamo linkato 
PLEXER.OBJ e PCONT.OBJ lasciando al suo in¬ 
terno l’istruzione .block 64-$%64 e senza inserire 
la direttiva .windowend. 

In fig.9 potete vedere la mappa della memoria del 
programma .HEX risultante. 

Il programma PCONT.OBJ (vedi Module) inizia 
all’indirizzo di memoria 0800h e termina all’indiriz¬ 
zo 0800h + 008Ah, cioè a 088Ah, mentre il pro¬ 
gramma PLEXER.OBJ inizia proprio da 088Ah e 
termina a 088Ah + 0049h, cioè a 08D3. 

Abbiamo poi simulato l’esecuzione del programma 
.HEX con un Simulatore Software e in fig.10 pote¬ 
te avere la riprova di quanto affermato poco sopra. 

In alto è evidenziata l’ultima istruzione eseguibile 
di PCONT e cioè jp loop seguita da una serie di i- 
struzioni jrnz che indirizzano sempre al byte suc¬ 
cessivo. Questo è il risultato dell’inserimento dell’i¬ 
struzione .block 64-$%64 che il compilatore tra¬ 
duce appunto in tanti salti di 1 byte fino a quando 
non arriva ad un blocco di memoria divisibile esat¬ 
tamente per 64. 

Infatti, quasi in fondo alla figura compare la label 
digit che identifica il punto di memoria esatto in cui 
sono stati inseriti i dati con i .byte e alla sua sini¬ 
stra compare l’indirizzo di memoria relativo e cioè 
0880h che è appunto un indirizzo divisibile esatta¬ 
mente per 64. 

Spostate lo sguardo più sotto e nella riga eviden¬ 
ziata vedrete l’istruzione mulplx Id a,lsb, che è la 
prima istruzione del programma PLEXER e si tro¬ 
va effettivamente all’indirizzo di memoria 088Ah. 

Vediamo invece cosa succede inserendo .window 
al posto di .block 64-$%64 e aggiungendo .win- 










3l Assembler 


dowend. Ricompiliamo in Assembler il programma 
PCONT in formato .OBJ con il comando: 


Ind. 

Codice 

Label 

Mnemonico 

G866 

E983 


jp 

loop 

G868 

C18B 

main7 

cali 

decrem 

086A 

E983 


jp 

loop 

086C 

00 


jrnz 

8 6Dh 

086D 

00 


jrnz 

8 6Eh 

086E 

00 


jrnz 

8 6Fh 

086F 

00 


jrnz 

370h 

087O 

00 


jrnz 

871h 

0871 

00 


jrnz 

872 h 

0872 

00 


jrnz 

873 h 

0873 

00 


jrnz 

374h 

0874 

00 


jrnz 

S75h 

0875 

00 


jrnz 

37 6h 

0876 

00 


jrnz 

S77h 

0877 

00 


jrnz 

878h 

0878 

00 


jrnz 

S79h 

0879 

00 


jrnz 

S7Ah 

087À 

00 


jrnz 

S7Bh 

087B 

00 


jrnz 

S7Ch 

087C 

00 


jrnz 

S7Dh 

087D 

00 


jrnz 

S7Eh 

087E 

00 


jrnz 

87Fh 

087F 

00 


jrnz 

digit 

OSSO 

CO 

digit 

jrnz 

S79h 

OSSI 

F9A4 


jP 

A4Fh 

0883 

BO 


jrnz 

S7Ah 

0884 

9992 


JP 

92 9h 

0886 

82 


jrnc 

S77h 

0887 

F8 


jrnz 

887h 

0888 

80 


jrnz 

S79h 

0889 

90 


jrnz 

S7Ch 

OSSA 

1F84 

mulplx 

ld 

a, lsb 

088C 

5740 


addi 

a,40h 


Fig.10 L’istruzione .block 64-$%64 è stata 
tradotta dal compilatore in salti di 1 byte fi¬ 
no ad un blocco di memoria divisibile per 
64. Infatti i dati .byte, identificati dalla label 
digit, vengono inseriti all’indirizzo 0880h, 
che è divisibile per 64. 


ast6 -L -O PCONT.ASM. 

Abbiamo inserito anche l’opzione -L perché vo¬ 
gliamo generare anche PCONT.LIS. 

Quando il compilatore incontra la direttiva .window 
prosegue fino a che non trova .windowend (che 
deve sempre essere inserita) e “memorizza” i dati 
(.byte, .ascii, ecc.) definiti tra questi estremi in u- 
na area rilocabile particolare definita come Win¬ 
dow section. 

In fig.11 abbiamo riprodotto la parte del file 
PCONT.LIS che riguarda queste direttive. 
All’altezza della riga 119 potete notare la scritta 
W00 che appunto rappresenta l’assegnazione alla 
Window section dei nostri 10 byte di data space i- 
dentificati dalla label digit, visibili a destra nella 
stessa riga. 

Notate inoltre che a fianco di W00 c’è il numero 
0000: normalmente questo numero rappresenta la 
locazione di memoria in cui verrà memorizzata l’i¬ 
struzione e in questo caso i nostri 10 bytes ver¬ 
ranno “memorizzati” a partire daH’indirizzo 0 della 
Window section. 

A questo punto possiamo linkare PCONT.OBJ e 
PLEXER.OBJ per ottenere l’eseguibile .HEX e in 
fig.12 riportiamo la mappa di memoria risultante. 
Notate subito che rispetto alla mappa precedente 
(vedi fig.9) vi è una Window section che inizia a 
08B5h ed è lunga OOOAh (cioè i 10 byte di digit). 
La stessa Window section è poi richiamata più in 
basso, nel programma PCONT.OBJ, nella terza ri¬ 
ga della seconda colonna (vedi type W). 


113 SOI 0068 0100 SOI 0068 91 main7 cali decrem 

file PCONT.lis page 4 

PCONT 


114 

SOI 

006A 

E903 

SOI 

006A 

92 

jp loop 

115 






93 


11 6 






94 


117 






95 

; tabella con i segmenti per far appa 

118 






98 

.window 

119 

UOO 

0000 

CO 

UOO 

0000 

97 

digit .byte 192,249,164,176,153 

120 

UOO 

0001 

F9 

UOO 

0001 

97 


121 

UOO 

0002 

A4 

UOO 

0002 

97 



Fig.11 Ricompilando il programma PCONT dopo aver inserito le direttive .window e .win¬ 
dowend, il compilatore “memorizza” le istruzioni racchiuse tra queste due direttive in un’a¬ 
rea rilocabile definita window section: notate la scritta W00 all’altezza della riga 119. Il nu¬ 
mero che segue (0000) rappresenta la locazione di memoria in cui vengono memorizzate 
le istruzioni racchiuse tra le direttive .window e .windowend. 



















UIND0U 

SECTI0NS: 


number 

start 

end size 

0 

08B5 

08BE GOGA 

M0DULE 

PCONT.OBJ 


section 

type 

start size 

1 

P 

0800 00GC 

32 

P 

0FF0 0010 

0 

u 

08B5 000A 

M0DULE 

PLEXER.OBJ: 

section 

type 

start size 

1 

P 

086C 0049 


Fig.12 Mappa della memoria risultante dal link 
dei programmi PCONT.OBJ e PLEXER.OBJ 
dopo aver inserito le direttive .window e .win- 
dowend. Rispetto alla fig.9, c’è una window 
section lunga esattamente 10 byte (OOOAh), il 
cui inizio non è più a 0000, ma a 08B5, per¬ 
ché il linker ha posizionato la window section 
in coda a tutte le istruzioni. 



Fig.13 Se la differenza tra la prima locazio¬ 
ne di memoria ROM divisibile per 64 e la lo¬ 
cazione dell’ultima istruzione è maggiore 
dell’area window section, i dati vengono in¬ 
seriti prima di questa locazione. 


Notate però che l'indirizzo della Window section 
non è più 0000 come era in PCONT.LIS di fig.11 
ma è diventato come già detto 08B5h. 

Il linker infatti ha unito in sequenza le istruzioni dei 
programmi PCONT e PLEXER e solo dopo, in co¬ 
da a tutto, ha “rilocato” la Window section. 

Per fare questo calcola innanzitutto la grandezza 
dell’area dati che si vuole inserire in Program Spa¬ 
ce tramite Window section (nel nostro esempio di¬ 
git sono 10 bytes), poi si posiziona alla prima lo¬ 
cazione di Program Space divisibile esattamente 
per 64 successiva all’ultima istruzione del pro¬ 
gramma finale .HEX. 

Se la differenza fra questa locazione e quella rela¬ 
tiva all’ultima istruzione del programma è maggio¬ 
re della grandezza dell’area dati da inserire (digit), 
inserisce i dati prima di questa locazione (vedi 
fig.13), se invece è minore, li inserisce dopo (vedi 
fig-14). 

Per concludere, con le direttive .window e .win- 
dowend, i dati da inserire in Program Space ven¬ 
gono automaticamente posizionati in coda a tutte 
le istruzioni, in un area già ottimizzata evitando co¬ 
sì inutili sprechi di memoria e soprattutto predi¬ 
sponendoli ad essere caricati in maniera corretta 
nella Data Rom Window. 


Nota: nella rivista N.190 abbiamo spiegato il cor¬ 
retto utilizzo della Data Rom Window. 



Fig.14 Se la differenza tra la prima locazio¬ 
ne di memoria ROM divisibile per 64 e la lo¬ 
cazione dell’ultima istruzione è minore 
dell’area window section, i dati vengono in¬ 
seriti dopo questa locazione. 
























L’unica restrizione all’uso di queste direttive è che 
tra .window e .windowend si possono inserire un 
massimo di 64 byte di dati altrimenti il compilatore 
Assembler segnalerà questo errore: 

Error current program section overflow (fatai) 

In questo caso dovrete spezzare i vostri dati in bloc¬ 
chi di massimo 64 byte e utilizzare più volte le di¬ 
rettive .window .windowend come riportato nell’e¬ 
sempio che segue: 

.window 

digOI .byte . 


.windowend 

.window 

dig02 .ascii . 

.byte . 

.windowend 

A questo punto abbiamo terminato l’analisi del pro¬ 
gramma PCONT.ASM e possiamo dedicarci al pro¬ 
gramma PLEXER.ASM. 

Innanzitutto potete notare che davanti alle istruzio¬ 
ni che abbiamo estratto dal programma originale 
CONTA.ASM (vedi il listato in fig.3), sono state in¬ 
serite le direttive necessarie al programma 
PLEXER per essere compilato: 

.title “plexer” 

.vers “st62e25” 

.w_on 

.romsize 4 

Abbiamo quindi aggiunto la direttiva .pp_on (vedi 
riga evidenziata in giallo) che, come abbiamo già 
detto, attiva la “paginazione” e abbiamo ripetuto la 
definizione dei registri con la direttiva .input e la 
definizione delle variabili Isb e msb, che avevamo 
già definito in PCONT.ASM. 

Questa ripetizione si è resa necessaria dal mo¬ 
mento che queste variabili e alcuni registri vengo¬ 
no utilizzati nel programma e perciò se non li a- 
vessimo segnalati, il compilatore avrebbe dato er¬ 
rore e non avrebbe compilato il programma nel for¬ 
mato oggetto .OBJ. 

Se state pensando che si potevano evitare queste 
istruzioni definendo i registri e le variabili come e- 
sterni con la direttiva .extern, siete in errore. 

Come infatti abbiamo già detto, ma forse è utile ri¬ 
petere, possono essere definite come .extern so¬ 
lamente labels di Program Space e di Data Rom 
Windows, mentre i registri, le variabili di Data spa¬ 


ce e le costanti (.def, .equ, .set) non possono es¬ 
sere definite con questa direttiva. 

E’ però importante farvi notare che le variabili Isb 
e msb sono state definite ad un indirizzo di me¬ 
moria differente da quello che avevano nel pro¬ 
gramma PCONT.ASM (vedi di fig.2). 

Torneremo più avanti su questo argomento. 

In conclusione sottolineiamo che anche in questo 
programma è stata inserita la direttiva .section 1, 
che oramai conoscete. 

A questo punto assembliamo in formato .OBJ i pro¬ 
grammi PCONT.ASM e PLEXER.ASM digitando al 
prompt di DOS: 

ast6 -L -O PCONTA.ASM 
ast6 -L -O PLEXER.ASM 

Otteniamo così PCONTA.OBJ e PLEXER.OBJ, 

che ora possiamo “unire” con il linker Ist6 per ot¬ 
tenere un programma eseguibile al quale diamo no¬ 
me XCONTA.HEX. 

Ottenere il formato .HEX con il linker Ist6 

Finora abbiamo sempre parlato di “unire” più pro¬ 
grammi .OBJ per ottenere un programma esegui¬ 
bile .HEX. 

In realtà è meglio utilizzare il termine collegare, 
perché i programmi vengono collegati insieme e o- 
gni indirizzo di memoria, che prima era relativo ad 
un singolo programma, diventa indirizzo assolu¬ 
to nel programma finale .HEX. 

A questo punto penserete che essendo i program¬ 
mi correttamente compilati in formato .OBJ, linkan- 
doli non incontreremo alcun ostacolo. 

In realtà le cose non stanno proprio così, ma poi¬ 
ché non sarebbe utile anticipare i problemi, vedia¬ 
mo per ora come si lancia il linker Lst6 per colle¬ 
gare PCONT.OBJ e PLEXER.OBJ e ottenere 
XCONTA.HEX. 

Al prompt di DOS digitiamo: 

Ist6 -S -I -T -V -M -O XCONTA PCONT PLEXER 

Le scritte -S -I -T -V -M sono opzioni specifiche 
del linker Lst6 che verranno spiegate in maniera 
completa nel prossimo articolo. 

Per non appesantire questo articolo, ci soffermia¬ 
mo solo su -O XCONTA PCONT PLEXER. 

Nota: attenzione a non confondere l’opzione -O 
del linker con l’opzione -O deH’Assembler. 






L’opzione -O del linker seguita dal nome del pro¬ 
gramma finale, nel nostro caso XCONTA, serve ad 
indicare al linker come dovrà chiamare il program¬ 
ma eseguibile .HEX. 

Come potete notare noi ci siamo limitati a scrivere 
XCONTA, perché l’estensione .HEX viene messa 
automaticamente dal programma Ist6. 

Se avessimo voluto ottenere un programma con u- 
na diversa estensione avremmo dovuto scrivere il 
nome per esteso: ad esempio -O XCONTA.PGM. 

Dopo il nome dell’eseguibile, scriviamo in succes¬ 
sione il nome dei programmi da concatenare, cioè 
PCONT e PLEXER, omettendo anche stavolta l’e¬ 
stensione .OBJ, perché assunta di default. 

E’ invece molto IMPORTANTE l’ordine in cui ven¬ 
gono definiti i programmi da linkare, perché il linker 
seguirà quell’ordine per collegarli. 

Nel nostro esempio i programmi sono due, ma po¬ 
trebbero essere molti di più. 


CONTROLLO delle CONDIZIONI 

Lanciamo quindi il linker e, come già anticipato, a vi¬ 
deo compaiono le segnalazioni di errore visibili in 
fig.15. Dopo la visualizzazione della versione del 
Linker e la segnalazione del copyright c’è la scritta: 

passi : 

Il linker o, come più correttamente sarebbe giusto 
chiamarlo, il Linkage Editor, agisce infatti in due fa¬ 
si o passi. 

Il primo passo o passi è quello di controllare che 
in tutti i programmi .OBJ da linkare ci siano le con¬ 
dizioni per poterli collegare segnalando eventuali 
errori. 

Il secondo passo o pass2 è quello specifico di col¬ 
legare ogni singola istruzione e locazione di me¬ 
moria dei vari programmi in modo da ottenere un 
unico programma eseguibile. E’ in questa seconda 
fase che le locazioni di memoria dei singoli pro¬ 
grammi vengono in un certo senso sistemate una 
in “coda” all’altra con la conseguente “rilocazione” 
o “rimappatura” degli indirizzi. 
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In tutti gli articoli sul linguaggio di programmazione Assembler usato dai microprocessori 
ST6, vi abbiamo sempre spiegato le procedure per scrivere i programmi unendo la teoria, 
della quale non si può fare a meno, alla pratica, con esempi che fossero semplici e imme¬ 
diati. Chi ha avuto la costanza di seguirci non ne è rimasto deluso e con questo articolo sul 
linker Lst6 potrà acquisire ulteriori elementi per programmare senza problemi. 
























Sotto pass 1 leggiamo: 

<PCONT.obj>: program section(s) size is 0x7C (124), window(s) size is OxA (10) 


Il linker calcola e segnala l’occupazione di Program 
Space (124 bytes) e l’occupazione di window sec- 
tion (10 bytes: ricordate la definizione di digit tra 
.window e .windowend) del programma PCONT. 

Di seguito c’è: 

<PLEXER.obj>: program section(s) size is 0x49 (73), window(s) size is 0x0 (0) 


Il calcolo della memoria di Program Space (73 by¬ 
tes) e l’eventuale presenza di window section, av¬ 
viene anche per il programma PLEXER. 

Nelle tre righe seguenti leggiamo: 

Ist6 : ** undefined symboi <decrem> ; first referenced in file <PCONT.obj> 
Ist6 : ** undefined symboi <increm> ; first referenced in file <PCONT.obj> 
Ist6 : ** undefined symboi <mulplx> ; first referenced in file <PCONT.obj> 
Ist6 : <3> fatai error(s) occurred 


Effettuando un controllo sulla possibilità di colle¬ 
gare PCONT e PLEXER, il linker rileva tre ano¬ 
malie relative alle routine identificate dalle labels 
decrem, increm e mulplx e pertanto termina sen¬ 
za generare il programma eseguibile. 

Segnala queste routine come indefinite (undefined 
symboi ) e ci informa che il primo riferimento (first 
referenced) è nel programma PCONT. 


sono state correttamente definite esterne con la di¬ 
rettiva .extern decrem,increm,mulplx. 

A questo punto controlliamo anche il programma 
PLEXER.ASM, ma anche qui decrem, increm e 
mulplx sono definite e usate correttamente. 
Dovrebbe perciò essere tutto a posto, ma nono¬ 
stante ciò il linker le segnala come indefinite. 


La prima cosa che dobbiamo fare è controllare il L’errore deriva dal fatto che nel programma 

programma PCONT.ASM dove però le tre labels PLEXER non è stata inserita la direttiva .global. 


C : \ >LST6 -s -I -T -U -M -0 XC0NTA PCONT PLEXER 
STG Linkage Editor uersion 3.40 

Copyright (C) SGS-TH0MS0N Microelectronics May 1995 
passi : 

<PC0NT.obj>: program section(s) size is 0x7C (124), window(s) size is OxA (IO) 
<PLEXER.obj>: program section(s) size is 0x49 (73), window(s) size is 0x0 (0) 

Is16: ** undefined symboi <decrem> ; first referenced in file <PC0NT.obj> 

lst6: ** undefined symboi <increm> ; first referenced in file <PC0NT.obj> 

lst6: ** undefined symboi <mulplx> ; first referenced in file <PC0NT.obj> 

lst6: <3> fatai error(s) occured 


Fig.15 II programma linker agisce in due fasi o passi. Nella prima fase controlla se nei 
programmi .OBJ da linkare ci sono i presupposti per il loro collegamento. In questo ca¬ 
so non passa alla seconda fase perché rileva delle anomalie sull’uso delle labels decrem, 
increm e mulplx segnalandoci che il loro primo riferimento si trova in PCONT.OBJ. 








La direttiva .global 


RILOCAZIONE degli INDIRIZZI 


Questa direttiva è assolutamente ininfluente in fa¬ 
se di compilazione in formato .OBJ e la prova è 
data dal fatto che il compilatore non ha segnalato 
nessun errore assemblando PLEXER.ASM. 


Nella fig.16 abbiamo riportato la videata che ap¬ 
pare dopo aver lanciato per la seconda volta il 
linker. 


Quando però si devono linkare programmi che con¬ 
tengono la direttiva .extern per segnalare l’utilizzo 
di routine esterne, nel programma che effettiva¬ 
mente contiene queste routine bisogna inserire la 
direttiva .global seguita dalla definizione delle la- 
bels di queste routine. 

In questo modo segnaliamo al linker che queste 
routine sono richiamate in altri programmi e, in un 
certo senso, le rendiamo “disponibili”. 

E’ importante ricordare che .global deve essere 
obbligatoriamente inserita prima della definizione 
delle routine che vogliamo rendere utilizzabili in al¬ 
tri programmi. 

Il listato visibile in fig.3 va perciò modificato inse¬ 
rendo nel programma PLEXER.ASM, prima di 
.section 1 l’istruzione: 

.global decrem,increm,mulplx 

Ovviamente il programma va ricompilato per ge¬ 
nerare PLEXER.OBJ e poi va rilanciato il linker. 


Questa volta sotto passi non vengono segnalati 
errori, ma appare: window #0 (10 bytes) mapped 
in program page #1, at offset 0xb5. 

Questa scritta ci informa che, grazie alle direttive 
.window e .windowend inserite in PCONT, il linker 
ha rilocato (mapped) all’indirizzo 0B5h di Program 
page 1 un’area dati di 10 bytes. 

Il linker passa quindi alla seconda fase e ne dà il 
resoconto sotto la scritta: 

pass2 : 

Il collegamento vero e proprio di PCONT e 
PLEXER è stato effettuato e segnala che in 
PCONT ha rilevato l’utilizzo delle tre routine ester¬ 
ne e che in PLEXER ha rilevato le stesse routine 
definite con .global e ha assegnato loro un indi¬ 
rizzo assoluto di memoria Program Space: 

decrem 89Eh 

increm 889h 

mulplx 86Ch 


STG Linkage Editor uersion 3.40 

Copyright (C) SGS-THOMSON Microelectronics May 1995 
passi : 

<PC0NT.obj>: program section(s) size is 0x7C (124), window(s) size is Oxtì (10) 
<PLEXER.obj>: program section(s) size is 0x49 (73), window(s) siz© is OxO (0) 
window tt0 (10 bytes) mapped in program page ttl, at offset 0xb5 
pass2: 

<PC0NT.obj > 

reference to <decrem> external 
reference to <increm> external 
reference to <mulplx> external 
<PLEXER.obj > 

definition of <decrem> global program 89E(2206) 
definition of <increm> global program 889(2185) 
definition of <mulplx> global program 86C(2156) 
program section(s) size is 0xCF (207) 

<XC0NTA.hex>: hexadecimal image 
<XC0NTA.dsd>: dsd file 
<XC0NTA.sym>: namelist 


Fig.16 II linker dà un resoconto scritto anche della 2° fase, che consiste nel collegare o- 
gni singola istruzione e locazione di memoria così da ottenere un eseguibile .HEX. 







Inoltre segnala che la grandezza del programma e- 
seguibile sarà di OCFh bytes di Program Space e 
cioè di 207 bytes a partire da program section 1, e 
cioè dall’indirizzo di memoria 0800h (vedi la tabel¬ 
la in fig.5). Infine segnala che ha generato: 

XCONTA.hex 

XCONTA.dsd 

XCONTA.sym 

Nota: non ci soffermiamo sulle peculiarità dei pro¬ 
grammi con estensione .dsd e .sym ai quali ab¬ 
biamo dedicato l’articolo apparso sulla rivista N.194. 

Questa volta il linkaggio è andato a buon fine quin¬ 
di non ci resta che effettuare una semplice prova 
di simulazione per verificare se XCONTA.HEX fun¬ 
ziona correttamente. 

Se vi ricordate, in entrambi i programmi PCONT e 
PLEXER avevamo definito le variabili Isb e msb, 
ma in locazioni di memoria diverse. 

Poiché il linker non ha segnalato nessuna anoma¬ 
lia, siamo un po’ curiosi di vedere cosa succede 
nella simulazione. 

Carichiamo perciò il software simulatore, il cui uso 
è stato spiegato nelle riviste N.184 e N.185, ed e- 
seguiamo la simulazione istruzione per istruzione fi¬ 
no ad arrivare al punto visibile in fig.17, dove in gial¬ 
lo sono evidenziate le istruzioni che nel programma 
PCONT riguardavano le variabili Isb e msb, cioè: 

Idi lsb,00h 

Idi msb,00h 


JÌ Assembler 


Ind. 

Codice 

Label 

Mnemonico 


□ 82 B 

4D 

tini int 

reti 



□ 82 C 

4D 

BC int 

reti 



□ 82 D 

4D 

A int 

reti 



□ 82 E 

4D 

nini int 

reti 



□ 82 F 

□DD8FE 

main 

Idi 

wdog,FEh 


□ 832 

0D8700 


Idi 

Isb,OOh 


□ 835 

0D8800 


Idi 

msb,OOh 


□ 838 

0D8601 


Idi 

up dw,01h 


□ 83 B 

□DC922 


Idi 

drw,22h 


□ 83 E 

□D8411 

loop 

Idi 

Isb, Uh 


□ 841 

□D85FF 

maini 

Idi 

msb,FFh 


□ 844 

□DD8FE 

main2 

Idi 

wdog,FEh 


□ 847 

C18 6 


cali 

mulplx 


□ 849 

FF85 


dee 

de 12 


□ 84B 

14 


juz 

main3 


Fig.17 In giallo sono evidenziate le istru¬ 
zioni Idi delle variabile Isb e msb del pro¬ 
gramma PCONT; in verde altre istruzioni 
che non rispettano il listato di PCONT. Vi 
facciamo notare (vedi colonna opcode) che 
le locazioni di memoria sono differenti. 


Confrontando il loro opcode (vedi colonna codice 
in fig.17) con il listato di fig.2, si può notare che so¬ 
no corrette. L’operazione Idi infatti, avviene esat¬ 
tamente nelle due locazioni di memoria definite in 
PCONT, cioè 087h e 088h. 

Sempre in fig.17 abbiamo evidenziato in verde al¬ 
tre due istruzioni, cioè: 

loop Idi lsb,11h 

maini Idi msb,FFh 

che sono invece sbagliate. Infatti, verificando il li¬ 
stato di PCONT dovevano essere: 

loop Idi del1,11h 

maini Idi del2,FFh 

Verificando il loro opcode, possiamo vedere che 
l’operazione di Idi avviene nelle locazioni 084h e 
085h, che corrispondono alle locazioni di Isb e 
msb definite nel programma PLEXER. 

Il simulatore che, come sapete benissimo, utilizza 
il file con estensione .dsd per assegnare le eti¬ 
chette delle variabili e dei registri e rendere così 
leggibile il programma, quando ha decodificato le 
due ultime opcode, ha visualizzato le labels corri¬ 
spondenti agli indirizzi 084h e 085h, che in questo 
file corrispondono alle etichette dell e del2 del pro¬ 
gramma PCONT. 

In fig.18 riportiamo il contenuto del file XCON¬ 
TA.DSD, dove potete vedere che Isb e msb sono 
infatti definite 2 volte e in locazioni di memoria di¬ 
verse. 

Inoltre, dell e del2 hanno la stessa locazione di 
memoria della seconda “serie” di Isb - msb. 

Se però guardate più attentamente, vedrete che 
anche tutti i registri, l’accumulatore a, le porte lo¬ 
giche sono definite due volte, anche se in questo 
caso nella stessa locazione di memoria. 

Questo sta a significare che nonostante il linker non 
abbia segnalato errore, c’è un problema. 

Per poter assemblare in formato .OBJ sia PCONT 
che PLEXER, abbiamo dovuto inserire in entram¬ 
bi i programmi le definizioni standard dei registri, 
dell’accumulatore, delle porte logiche e delle eti¬ 
chette utilizzate, perché altrimenti il compilatore a- 
vrebbe segnalato errore. 

Quando però il linker ha unito i due .OBJ, ha co¬ 
me “sdoppiato” questi campi, generando una evi¬ 
dente confusione. 

Per impedire che questo si verifichi ci vengono in 
aiuto due direttive: .notransmit e .transmit. 


















Fig.18 II programma XCONTA.DSD riferito alle variabili Isb e msb definite due volte in due 
differenti locazioni di memoria. Come potete notare, le istruzioni dell e del2 hanno le stes¬ 
se locazioni di memoria della seconda serie di variabili Isb e msb. Anche le definizioni dei 
registri, dell’accumulatore, delle etichette ecc., sono state sdoppiate provocando confu¬ 
sione. Per ovviare a ciò si utilizzano le direttive .notransmit e .transmit. 



Fig.19 Parte del listato del programma 
PLEXER.ASM in cui abbiamo inserito le di¬ 
rettive .notransmit e .transmit. 


Le direttive .notransmit e .transmit 

Come abbiamo già visto per la direttiva .global, an¬ 
che le direttive .notransmit e .transmit non sono 
strettamente necessarie nella fase di compilazione 
in formato .OBJ, ma vanno assolutamente inserite 
quando i programmi da linkare contengono le de¬ 
finizioni delle stesse variabili, degli stessi registri, 
delle stesse etichette ecc. 

In questi casi è sufficiente che in uno dei programmi 
venga inserita .notransmit prima delle definizioni 
delle variabili comuni, e .transmit immediatamen¬ 
te dopo l’ultima variabile comune. 

In questo modo il linker utilizza le variabili, i regi¬ 
stri ecc. di un solo programma e collega tutte le i- 
struzioni relative a queste locazioni. 

Nel nostro caso, abbiamo inserito le direttive nel 
programma PLEXER.ASM come riportato in fig.19, 
e poi abbiamo ricompilato il programma per avere 
PLEXER.OBJ e abbiamo rilanciato il linker. 

In fig.20 riportiamo il file XCONTA.DSD corretto. 














Apriamo un editor qualsiasi e digitiamo: 



lsb 

87 

00 

R 

U 


msb 

88 

00 

R 

U 


pdir 

_a 

C4 

00 

R 

U 

pdir 

_b 

C5 

00 

R 

U 

pdir 

_c 

CG 

00 

R 

U 

psc 

D2 

00 

R 

U 


ter 

D3 

00 

R 

U 


ior 

C8 

00 

R 

U 


drw 

C9 

00 

R 

U 


popt 

_a 

CC 

00 

R 

U 

popt 

_b 

CD 

00 

R 

u 

popt 

_c 

CE 

00 

R 

u 

port 

_a 

CO 

00 

R 

u 

port 

_b 

CI 

00 

R 

u 

port 

_c 

C2 

00 

R 

u 

dell 

84 

00 

i R 

U 


del2 

85 

00 

i R 

u 


, A FF 

00 

R 

U 



U 82 

00 

R 

U 



U 83 

00 

R 

U 



X 80 

00 

R 

U 



V 81 

00 

R 

U 



adcr 

DI 

00 

i R 

u 


addr 

DO 

00 

i R 

u 


wdog 

D8 

00 

i R 

u 


tscr 

D4 

00 

i R 

u 


up_dw 86 00 

R U 


Fig.20 II file XCONTA.DSD ottenuto dopo a- 
ver inserito correttamente le direttive .no- 
transmit e .transmit. 


ULTIME CONSIDERAZIONI 

Nell’esempio che vi abbiamo illustrato, abbiamo 
linkato due soli programmi, quindi è stato relativa¬ 
mente facile ricordare come scrivere le giuste i- 
struzioni e la giusta sequenza per il linker. 

Quando però i programmi diventano tanti e tante 
sono le routine da utilizzare, potrebbe risultare dif¬ 
ficile gestire i programmi senza commettere nes¬ 
sun errore. 

Per questo motivo vi suggeriamo un semplice me¬ 
todo, utilizzato da molti programmatori, che vi con¬ 
sente di avere a disposizione anche il listato del 
programma eseguibile che si ottiene con il linker. 
In questo modo potrete facilmente controllare l’op- 
code delle istruzioni e il loro indirizzamento nella 
memoria. 

Prendiamo ancora una volta ad esempio i files 

PCONT e PLEXER. 


ast6 -L -O PCONT 
ast6 -L -O PLEXER 

Ist6 -S -I -T -V -M -O XCONTA PCONT PLEXER 

quindi salviamo il file chiamandolo XCONTA.BAT. 

A questo punto, ogni volta che dovremo compilare 
o linkare i due programmi, sarà sufficiente scrive¬ 
re al prompt di DOS: 

XCONTA 

e automaticamente verranno lanciate in cascata 
prima le due compilazioni in formato .OBJ e poi il 
linker Ist6. 

Poiché nei comandi Assembler prima dell’opzione 
-O abbiamo inserito l’opzione -L, che genera an¬ 
che il formato .LIS dei programmi, quando viene 
lanciato il linker, oltre a essere generato il pro¬ 
gramma eseguibile, nei files .LIS vengono sostitui¬ 
ti gli indirizzamenti relativi con gli indirizzamenti as¬ 
soluti del programma finale. 

Avremo così a disposizione anche il listato defini¬ 
tivo di XCONTA, che potremo leggere in 

PCONT.LIS e PLEXER.LIS. 

Sebbene questa parte vi possa essere sembrata 
alquanto complicata, non dovete sottovalutare il fat¬ 
to che ottenere dei programmi collegando tra loro 
programmi già esistenti è una pratica comune ad 
altri linguaggi di programmazione. 

Pertanto coloro che intendessero approfondire an¬ 
che lo studio di altri linguaggi software, non po¬ 
tranno che trarre vantaggio dalla lettura degli arti¬ 
coli dedicati al linker per i microprocessori ST6. 


I PROGRAMMI LST6 E AST6 

Informiamo tutti i nostri lettori che è possibile sca¬ 
ricare il programma linker Ist6 unitamente alla ver¬ 
sione 4.50 dell’Assembler ast6 dal nostro sito: 

www.nuovaelettronica.it 

Entrambi i programmi sono gratuiti. 








QUALCOSA in più sul TIMER 


La funzione timer dei microprocessori ST6 e il suo 
corretto utilizzo nella programmazione con lin¬ 
guaggio Assembler, è uno degli argomenti che ab¬ 
biamo trattato fin dalle nostre prime lezioni. 

In quegli esempi però, non si è tenuto volutamen¬ 
te conto del fatto che alcuni tipi di micro, oltre i tre 
normali registri del timer, hanno un piedino, gra¬ 
zie al quale è possibile attivare alcune modalità di 
funzionamento particolari e molto interessanti. 

A seconda del modello di microprocessore, questo 
piedino può avere una differente numerazione e 
può essere indicato con la scritta TIMI (vedi fig.1) 
oppure con la scritta TIMER (vedi fig.2). 

Abbiamo quindi ritenuto opportuno scrivere una 
piccola appendice per spiegarvi brevemente i casi 
in cui va utilizzato questo piedino, che per como¬ 
dità chiameremo semplicemente TIMX (vedi fig.3). 

Con le sigle TSCR, TCR e PSC abbiamo invece 
chiamato i tre registri utilizzati dal timer. 

In fig.3 è riportato lo schema a blocchi interno che 
fa capo al timer del microprocessore ST6. 

Passiamo ora a spiegare a grandi linee come fun¬ 
ziona il timer dei micro ST6. 

Il timer non è nient’altro che un contatore (TCR) 
che si decrementa di 1 ogni volta che un altro con¬ 
tatore, chiamato prescaler (PSC), decrementan- 
dosi a sua volta ad ogni impulso generato da un 
clock interno o esterno, arriva a zero. 

Quando il ter arriva a zero, setta alcuni valori all’in- 
terno del registro di controllo TSCR. 

Ricaricando il contatore TCR e ripristinando il re¬ 
gistro TSCR, è possibile far ripartire il timer tutte le 
volte necessarie al suo utilizzo. 

E’ possibile inoltre impostare un divisore sul pre¬ 
scaler, di modo che questo contatore si decrementi 
solamente ogni 1, 2, 4, 8, 16, 32, 64 o 128 impul¬ 
si di clock (interni o esterni). 

Ma di questo abbiamo già parlato abbondante¬ 
mente e spiegato con numerosi esempi negli arti¬ 
coli dedicati ai microprocessori ST6. 

In questo articolo, parleremo solamente del regi¬ 
stro di controllo (vedi fig.4) e cioè del: 

TSCR Timer Status Control Register 



P Co/Ain 
PCI/TIMI/A in 
3 P CZ/Sin/Ain 
3 P C3/Sout/Ain 
3 P C4/Sck/Ain 

□ NMI 

□ RESET 
t CSC OUT 

CSC. IN 
P A 7/A in 
P AG/Ain 
P Ali/Ain 
P A4/Am 
P AJ/Ain 


SI 62T65C-ST 62E65C 


Fig.1 I microprocessori serie ST62T65C e 
ST62E65C hanno un piedino dedicato all’at¬ 
tivazione del timer. Questo piedino è il 27 e 
viene solitamente chiamato TIMI. 


Vcc 
TIMER 
DSC, IN 
OSC. OUT 
NMI 
Vpp 
RESET 
Ain*/P B7 
A in*/? BG 
Ain*/P OS 

ST6210C ST6220C 

Fig.2 I microprocessori serie ST6210C e 
ST6220C hanno un piedino dedicato all’at¬ 
tivazione del timer. Questo piedino è il 2 e 
viene solitamente chiamato TIMER. 



GND 

P AB/ZSmA Slink 
P Al/20 mA Sink 
P A2/20 mA Sink 
P A3/20 mA Sink 
P BO/Ain* 

P Bl/Ain* 

P B2/Ain* 

P B3/Ain* 

P B4/Ain* 


TIMX 



l____ 

Fig.3 Al piedino del timer, che per comodità 
abbiamo chiamato nei nostri esempi TIMX, 
fanno capo tre registri chiamati TSCR - 
PRESCALER - TCR. 
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i Fig.4 II registro TSCR, abbre- 
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TMZ 

ETI 

TOUT 

DOUT 

PSI 

PS2 

PSI 

PSO 

i viazione di Timer Status Con- 
i trol Register, consente il con- 
i frollo del Timer. In figura po- 
i tete vedere il suo formato. 

i 

1 

1 

1 



TSCR REGISTER 




Con questo registro si effettua il controllo comple¬ 
to del timer. Il formato del registro è: 


7 

6 

5 

4 

3 

2 

1 

0 

TMZ 

ETI 

TOUT 

DOUT 

PSI 

PS2 

PSI 

PSO 


Abbiamo contraddistinto i singoli bit con delle sigle 
e ora, bit per bit, ne diamo il significato, ma so¬ 
prattutto vediamo come vanno gestiti questi bit nei 
nostri programmi per ottenere le diverse funzioni. 


- bit 7 TMZ Timer Zero Bit 


Questo bit viene gestito in maniera automatica dal 
timer, ma può essere anche settato o resettato da 
programma. Quando il registro contatore del timer, 
cioè il registro ter, decrementandosi raggiunge lo 
zero, questo bit viene posto a 1 . 

Per questo motivo, ogni volta che bisogna iniziare 
un nuovo conteggio del timer, questo bit va reset¬ 
tato a 0, altrimenti il timer non riparte. 


- bit 6 ETI Enable Timer Interrupt 


Questo bit viene gestito attraverso il programma. 
Quando è posto a 0, l’interrupt del timer non vie¬ 
ne abilitato, quando invece è posto a 1, la richie¬ 
sta di interrupt del timer è abilitata. In questo ca¬ 
so, quando TMZ, cioè il bit 7, diventa 1, il pro¬ 
gramma salta al vettore relativo (definito nei nostri 
programmi-esempio con timjnt o tadjnt). 
Naturalmente dobbiamo avere correttamente abili¬ 
tato il registro ior all’inizio del nostro programma. 

I due bit che interessano direttamente il piedino 
TIMX del timer sono: 


- bit 5 TOUT Timers Output Control 

- bit 4 DOUT Data Output 


Entrambi questi bit vengono gestiti dal programma 
e consentono di selezionare una delle quattro dif¬ 
ferenti modalità del timer. 

Nota: in realtà le modalità sono tre, perché per le 
funzioni Output Mode, la modalità è la stessa e 
cambia solo il tipo di segnale in uscita, che può es¬ 
sere 0 o 1. 


Nella tabella successiva riportiamo le combinazio¬ 
ni possibili e le relative funzioni attivate. 


0 

0 

Input 

Event Counter 

0 

1 

Input 

Gated Mode 

1 

0 

Output 

Output Mode “0” 

1 

1 

Output 

Output Mode “1” 


Vediamo ora insieme i singoli casi. 


- Event Counter: TOUT = 0 DOUT = 0 


In questa modalità il piedino TIMX del micro viene 
configurato in input e diventa l’input clock del re¬ 
gistro prescaler psc. 

Il decremento del registro prescaler psc avviene 
solo quando viene rilevato un fronte di salita (ri- 
sing edge) su questo piedino. 

Questa modalità viene ad esempio utilizzata per ot¬ 
tenere un conta impulsi o un generico contato¬ 
re (vedi più avanti il primo programma-esempio). 


- Gated Mode: TOUT = 0 DOUT = 1 


In questa modalità il piedino TIMX viene configu¬ 
rato in input e il prescaler psc si decrementa sul 
clock del timer, cioè con la frequenza interna di¬ 
visa per 12. 

Questo avviene solamente quando sul piedino 
TIMX viene rilevato uno stato logico “high”, cioè 1 . 
Se lo stato è “low”, cioè 0, il registro prescaler psc 
non si decrementa mai ed il timer è bloccato fino 
al prossimo cambio di stato del piedino TIMX. 
Questa modalità viene ad esempio utilizzata per ot¬ 
tenere un semplice periodimetro o per misurare 
la durata di un impulso (vedi più avanti il secon¬ 
do peogramma-esempio). 


- Output Mode “0”: TOUT = 1 DOUT = 0 


In questa modalità il piedino TIMX viene configu¬ 
rato in output e il prescaler psc si decrementa sul 
clock del timer, cioè con la frequenza interna di¬ 
visa per 12. 

Quando il bit 7 TMZ diventa 1, sul piedino TIMX 
viene riportato il valore di DOUT e cioè 0. 


TOUT DOUT 


TIMER PIN MODALITÀ 














































Questa modalità viene ad esempio utilizzata per ot¬ 
tenere un generatore di frequenza. 


- Output Mode “1”: TOUT = 1 DOUT = 1 


Anche in questa modalità il piedino TIMX viene con¬ 
figurato in output e il prescaler psc si decremen- 
ta sul clock del timer, cioè con la frequenza inter¬ 
na divisa per 12. 

Quando il bit 7 TMZ diventa 1, sul piedino TIMX 
viene riportato il valore di DOUT e cioè 1 . 

Come la precedente, anche questa modalità viene 
utilizzata per ottenere un generatore di frequen¬ 
za (vedi più avanti il terzo programma-esempio). 


- bit 3 PSI Prescaler Initialize Bit 


Questo bit viene gestito attraverso il programma. 
Quando è posto a 0, il registro prescaler psc vie¬ 
ne inizializzato al valore 7Fh (in binario 01111111) 
e il suo conteggio viene bloccato. 

In questa condizione quindi il timer non funziona. 
Quando è posto a 1, il conteggio (decremento) del 
prescaler è attivo ed il timer funziona. 


- bit 2-1-0 PS2-1-0 Prese. Div. Factor 


Questi bit vengono gestiti attraverso il programma. 
La combinazione di questi tre bit permette di confi¬ 
gurare il fattore di divisione del registro prescaler 
psc come si vede nella tabella proposta di seguito. 

Grazie all’utilizzo corretto di questi tre bit, è possibi¬ 
le ottenere una vasta gamma di temporizzazioni. 


PS2 

PSI 

PS0 

DIVISORE 

0 

0 

0 

1 

0 

0 

1 

2 

0 

1 

0 

4 

0 

1 

1 

8 

1 

0 

0 

16 

1 

0 

1 

32 

1 

1 

0 

64 

1 

1 

1 

128 


Alla luce di quanto fin qui detto, è opportuno fare 
alcune piccole e semplici constatazioni. 

Quando si intende utilizzare il timer, è evidente che 
se il micro ST6 scelto dispone del piedino TIMI o 
TIMER, questo diventa praticamente riservato e 
non deve essere assolutamente utilizzato per sco¬ 
pi diversi da quelli elencati sopra, come, ad esem¬ 
pio, per gestire un pulsante o spedire dati ad un di¬ 
splay, perché il programma ed il relativo circuito po¬ 
trebbero non funzionare correttamente. 

Inoltre, occorre fare attenzione all’Option Byte dei 
micro della versione C. 

E’ infatti possibile che, in alcuni modelli, sia inseri¬ 
to un bit che permette di scegliere tra la modalità 
Pull-Up o la modalità No Pull-Up del piedino TI¬ 
MER. Questo fatto potrebbe influenzare la gestio¬ 
ne del timer. 

Infatti, se, ad esempio, in un programma che uti¬ 
lizza un micro modello ST6220C e che prevede l’u¬ 
tilizzo del timer in Gated Mode, non settiamo a 1 
il bit D2 dell Option Byte (vedi fig.5), bisognerà ri¬ 
cordarsi di farlo elettricamente collegando tra il pie- 



Fig.5 Quando utilizzate i micro della serie C che hanno il piedino del TIMER (vedi Timi e 
Timer nelle figg.1-2), ricordatevi di controllare se è possibile scegliere tra la modalità pull- 
up o no pull-up. Se così fosse, settate a 1 il piedino D2 dell Option Byte oppure ricorda¬ 
tevi di collegare una resistenza esterna di pull-up da 10.000 ohm al piedino Timer. 












































dino TIMX e il positivo di alimentazione una resi¬ 
stenza esterna di pull-up da 10.000 ohm, altrimenti 

il timer non partirà mai. 

Non crediate di poterlo fare tramite il programma, 
perché, come abbiamo già detto, in questi tipi di 
micro il piedino TIMER è riservato e quindi non è 
configurabile tramite i tre normali registri delle por¬ 
te (come, port_a, pdir_a e popt_a). 

ESEMPI 


Il bit 6 denominato ETI è a 1 perché vogliamo ge¬ 
stire l’interrupt del timer quando il contatore ter 
arriva a zero. 

I bit 2-1-0 denominati PS2-PS1-PS0 sono tutti a ze¬ 
ro perché vogliamo che il divisore del prescaler sia 
uguale a 1. 

In questo modo, ogni fronte di salita rilevato sul pie¬ 
dino TIMX, va a decrementare subito il contatore 
del timer ter. 


Per spiegare quanto fin qui detto, abbiamo scritto 
tre semplici e completi programmi-esempio funzio¬ 
nanti: 

contaimp.asm - durata.asm - ondaqua.asm 

Di seguito spieghiamo con maggiori dettagli le so¬ 
le istruzioni relative alla gestione del timer, ma voi 
trovate i sorgenti completi in questo cd-rom. 

Per facilitare il riconoscimento delle istruzioni all’in- 
terno del programma, abbiamo inoltre provveduto 
a numerarle. 

IL PROGRAMMA CONTAIMP.ASM 

Per esemplificare la modalità “Event Counter” ab¬ 
biamo scritto il programma CONTAIMP.ASM. 

In questo programma viene utilizzato il piedino 
TIMX di un microcontrollore ST6265 per “contare” 
gli impulsi. E’ previsto il conteggio di un massimo 
di 9999 impulsi, dopodiché si riparte. 

E’ inoltre prevista la visualizzazione in tempo rea¬ 
le di questo conteggio tramite la gestione di 4 di¬ 
splay numerici a 7 segmenti. 

Aprite con un normale editor, ad esempio Notepad, 
questo programma e posizionatevi alla riga da noi 
numerata 279, dove trovate queste istruzioni: 

Idi tcr,1 

Idi tscr,01001000b 

Con la prima istruzione abbiamo caricato il valore 
1 nel contatore ter. 

Con la seconda istruzione carichiamo il valore bi¬ 
nario 01001000 nel registro tscr. 

Se adoperate la tabellina che abbiamo utilizzato ad 
inizio articolo, potete capire meglio perché abbia¬ 
mo caricato questo numero nel registro tscr. 


7 

6 

5 

4 

3 

2 

1 

0 

TMZ 

ETI 

TOUT 

DOUT 

PSI 

PS2 

PSI 

PS0 

0 

1 

0 

0 

1 

0 

0 

0 


I bit 5 e 4 denominati TOUT e DOUT sono a zero 
per attivare la modalità “EVENT COUNTER”. 


Poiché noi abbiamo caricato il contatore ter con il 
valore 1, al primo impulso rilevato, il ter va a zero 
e attiva l’interrupt (vedi tadjnt). 

Il bit 7 denominato TMZ viene posto a 0, mentre il 
bit 3 denominato PSI viene posto a 1 e in questo 
modo il timer si attiva. 

A questo punto posizionatevi alla riga da noi nu¬ 
merata 104, dove trovate la routine: 

tadjnt 

per la gestione dell’interrupt del timer. 

Come abbiamo spiegato quando abbiamo parlato 
della modalità Event Counter, il programma attiva 
la routine tadjnt quando il contatore ter è a zero, 
cioè ad ogni impulso (fronte di salita) rilevato su 
TIMX e, tramite i due contatori che nel nostro pro¬ 
gramma abbiamo chiamato unidec e cenmil (vedi 
le istruzioni posizionate alle righe 48 e 49), effettua 
un conteggio da 0 a 9999 impulsi visualizzandone 
il risultato su 4 display numerici a 7 segmenti. 
Quando il conteggio degli impulsi arriva a 9999, i 
contatori vengono azzerati e il conteggio riparte. 

IL PROGRAMMA DURATA.ASM 

Per esemplificare la modalità “Gated Mode” ab¬ 
biamo scritto il programma DURATA.ASM. 

In questo programma viene utilizzato il piedino 
TIMX di un microcontrollore ST6265 per calcolare 
il tempo totale di accensione di una caldaia oppu¬ 
re di un innaffiatoio o anche di una pompa ecc., 
nell’arco delle 24 ore. E’ inoltre prevista la sua vi¬ 
sualizzazione su 4 display a 7 segmenti. 

Il tempo è calcolato in secondi-minuti-ore e sul 
display è possibile visualizzare a scelta i minuti ed 
i secondi oppure le ore ed i minuti, se si modifica¬ 
no alcune righe del programma sorgente. 

Quando la caldaia (o l’innaffiatoio ecc.) si spegne, 
mette a 0 lo stato logico del piedino TIMX e il con¬ 
teggio del tempo si ferma, quando si riaccende met- 












te a 1 lo stato logico di TIMX e il conteggio ripar¬ 
te. Il tempo massimo del conteggio è di 24 ore. 

Aprite ora con un editor, ad esempio Notepad, que¬ 
sto programma e posizionatevi alla riga da noi nu¬ 
merata 79, dove trovate le istruzioni: 

Idi ter,16 

Idi tscr,01011111b 

Anche in questo caso adoperate la tabellina che 
abbiamo utilizzato ad inizio articolo, per capire me¬ 
glio perché abbiamo caricato questo numero nel 
registro tscr. 


7 

6 

5 

4 

3 

2 

1 

0 

TMZ 

ETI 

TOUT 

DOUT 

PSI 

PS2 

PSI 

PSO 

0 

1 

0 

1 

1 

1 

1 

1 


Notate anzitutto che il bit 5 denominato TOUT è a 
0, mentre il bit 4 denominato DOUT è a 1. 


Questa “combinazione” serve per attivare la mo¬ 
dalità “GATED MODE”. 

I bit 2-1-0 denominati PS2 PS1 PSO sono tutti a 1, 
quindi il divisore del prescaler è settato a 128. 
Avendo utilizzato un quarzo da 2,4576 MHz e a- 
vendo caricato il contatore ter con il valore 16 e 
settato il prescaler a 128, abbiamo ottenuto una ba¬ 
se tempi di 10 millisecondi. 

II bit 6 denominato ETI è settato a 1 per attivare 
l’interrupt e quindi, ogni 10 millisecondi, il pro¬ 
gramma attiva la routine tadjnt (vedi istruzione al¬ 
la riga 104), dove gestisce sia il calcolo del tempo 
di utilizzo che la sua visualizzazione sui display. 

Nota: nel nostro programma le istruzioni sono scrit¬ 
te in modo da visualizzare i secondi e i minuti di 
utilizzo. Infatti, alla riga 139 trovate l’istruzione: 

Id a,secondi 

mentre alla riga 145 trovate l’istruzione: 

Id a,minuti 

Se invece dei minuti e dei secondi, volete visualiz¬ 
zare i minuti e le ore dovete cambiare la riga 139 
con l’istruzione: 

Id a,minuti 

e la riga 145 con l’istruzione: 

a,ore 


IL PROGRAMMA ONDAQUA.ASM 

Per esemplificare la modalità “Output Mode” ab¬ 
biamo scritto il programma ONDAQUA.ASM. 

Con questo programma generiamo un’onda qua¬ 
dra della frequenza di 100 Hz sul piedino TIMX. 

Anche in questo caso abbiamo previsto di utilizza¬ 
re un quarzo esterno che oscilli alla frequenza di 
2,4576 MHz e abbiamo opportunamente settato il 
contatore ter e il registro di configurazione tscr. 

Aprite dunque con un editor questo programma e 
posizionatevi alla riga da noi numerata 127 dove 
trovate le istruzioni: 

Idi ter,16 

Idi tscr,01111110b 

Adoperate anche in questo caso la tabellina che 
abbiamo utilizzato ad inizio articolo, per capire me¬ 
glio perché abbiamo caricato questo numero nel 
registro tscr. 


7 

6 

5 

4 

3 

2 

1 

0 

TMZ 

ETI 

TOUT 

DOUT 

PSI 

PS2 

PSI 

PSO 

0 

1 

1 

1 

1 

1 

1 

0 


Il bit 5 denominato TOUT è settato a 1 per attiva¬ 
re la modalità “Output Mode”. 


I bit 2-1-0 denominati PS2 PS1 PSO sono settati a 
1-1-0 in modo da configurare a 64 il divisore del 
prescaler. 

Con il quarzo a 2,4576 MHz, il contatore ter cari¬ 
cato con 16 e il divisore del prescaler a 64, abbia¬ 
mo ottenuto una base tempi di 5 millisecondi. 

Settando a 1 il bit 6 denominato ETI abbiamo atti¬ 
vato la richiesta di interrupt del timer e quindi o- 
gni 5 millisecondi il programma salterà alla routi¬ 
ne tadjnt visibile dalla riga 138 alla 148. 

II bit 4 denominato DOUT è stato configurato a 1. 
Questo significa che la prima volta che si attiva l’in¬ 
terrupt, nel piedino TIMX, che fino ad allora conte¬ 
neva uno stato logico 0 (in virtù delle istruzioni che 
si trovano dalla riga 119 alla riga 121), verrà “mos¬ 
so” il valore del bit DOUT e cioè 1 . 

Nelle attivazioni successive dell’interrupt del timer 
(vedi tadjnt dalla riga 138 alla riga 148), il bit 
DOUT verrà configurato alternativamente a 0 e poi 
ale così via, in modo da generare una forma di 
onda quadra a 100 Hz. 
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LAMPADA per CANCELLARE EPROM 


Recatevi presso un qualsiasi negozio di materiale 
elettrico e provate a richiedere delle lampade ul¬ 
traviolette che lavorino sui 2.300-2.700 Angstrom, 
e come è accaduto a noi, vi verranno proposte del¬ 
le comuni lampade Argon o delle lampade per ab¬ 
bronzarsi, che sono inadatte ai nostri scopi perché 
non emettono raggi ultravioletti sulla lunghezza 
d’onda richiesta. 

Dopo aver spiegato che le lampade ci servivano 
per cancellare delle EPROM, ci è stato suggerito 
di rivolgerci presso i negozi di computer, dove ab¬ 
biamo fatto un’amara scoperta. 

La maggior parte di queste rivendite è sprovvista 
di queste lampade o, nel migliore dei casi, i pochi 
modelli di cui dispongono hanno prezzi esagerati. 
Constatato che l’articolo sui microprocessori del¬ 
la serie ST62 (vedi rivista N.172/173) ha incontra¬ 
to un successo superiore alle nostre attese, tutti i 
lettori che hanno realizzato il programmatore 
LX.1170 ci hanno tempestato di richieste chieden¬ 
doci una lampada per cancellare gli ST62E. 

In passato avevamo disponibile una lampada per 
cancellare le memorie Eprom dei microprocesso¬ 
ri, che si poteva direttamente collegare ai 220 volt 
della rete, ma poiché è andata fuori produzione e 
quindi risulta anche per noi introvabile, ci siamo da¬ 
ti da fare per cercarne un’altra che la potesse so¬ 
stituire. 

La lampada che abbiamo trovato è di forma cilin¬ 
drica, ha un diametro di 1,5 cm e misura in lun¬ 
ghezza 30 cm; per funzionare ha bisogno di due 
zoccoli, di un reattore e di uno starter, e poiché 
anche questi componenti non sono facilmente re¬ 
peribili, abbiamo pensato di presentarla in Kit ai no¬ 
stri lettori. 

Inizialmente avevamo contattato qualche Industria 
per corredarla di un appropriato mobile, ma dopo 
aver conosciuto il prezzo per realizzarlo, abbiamo 
abbandonato questa idea, perché con solo quattro 
pezzi di legno ed un po’ d’iniziativa, chiunque po¬ 


trà realizzare un mobile adatto, risparmiando note¬ 
volmente. 

Noi, per realizzare il contenitore che vedete nelle 
foto, abbiamo chiesto ad un falegname nostro a- 
mico due tavolette delle dimensioni di 47 x 12 cm, 
che abbiamo adoperato come piano base e piano 
superiore, e due piccoli righelli alti 5,5 cm, che ab¬ 
biamo inchiodato ed incollato ai due lati delle ta¬ 
volette. 

A chi non piace tenere il contenitore grezzo, ba¬ 
sterà che si procuri un pennello ed un poco di ver¬ 
nice opaca per legno, oppure una bomboletta di 
vernice spray, e con una spesa irrisoria avrà un 
elegante cancella - Eprom. 

Con delle viti per legno abbiamo fissato sul piano 
superiore i due zoccoli per la lampada, lo zocco¬ 
lo per lo starter ed il reattore. 

Con del filo isolato di plastica abbiamo eseguito un 
semplice impianto elettrico (vedi fig.1) e per fis¬ 
sare le estremità del cordone di rete per i 220 volt 
abbiamo usato due mammuth. 

Sapendo che questa lampada può cancellare 
qualsiasi Eprom in circa 17-20 minuti, le abbia¬ 
mo collegato, dopo averlo programmato sui 20 mi¬ 
nuti, il timer LX.1181, che trovate pubblicato sul¬ 
la rivista N.174. 

Considerando la lunghezza della lampada, potrete 
cancellare contemporaneamente circa 10-12 me¬ 
morie. 

Collocate i microprocessori che volete cancellare 
sopra un cartoncino o sopra un sottile ritaglio di la¬ 
mierino o compensato, quindi infilateli sotto la lam¬ 
pada in modo che la loro finestra risulti distante 
all’incirca 2 cm dal bulbo in vetro. 

Come abbiamo già avuto modo di accennare in pre¬ 
cedenti articoli, prima di inserire il microprocesso¬ 
re sotto la lampada assicuratevi che la sua fine¬ 
stra sia pulita. Se così non fosse, sgrassatela con 
un batuffolo di cotone imbevuto di alcol o di ace¬ 
tone. 











Non è conveniente fissare per molti minuti la luce 
viola emessa dalla lampada accesa, perché irri¬ 
tante per gli occhi. 

Sul numero 172/173 l’articolista ha scritto che que¬ 
sta luce nuoce gravemente agli occhi, ma ha un 
poco esagerato, forse perché non avendola mai 
personalmente utilizzata, si è lasciato influenzare 
dalle affermazioni del tecnico. 

In realtà l’occhio non viene danneggiato, come si 
potrebbe erroneamente dedurre da quanto scritto, 
ma si irrita provocando una condizione analoga 
(anche se molto inferiore) a quella prodotta quan¬ 
do si guarda l’arco di una saldatura elettrica sen¬ 
za la protezione degli occhiali. 

Quindi se guardate per 5-6 minuti di seguito i rag¬ 
gi ultravioletti emessi dalla lampada, vi sembrerà 
di avere negli occhi dei fastidiosi ed irritanti gra¬ 
nelli di sabbia. 

Per far scomparire il dolore, basterà fare qualche 
impacco con una soluzione di acido borico. 


Per premunirvi contro questo fastidioso inconve¬ 
niente, coprite, per il tempo che la lampada rima¬ 
ne accesa, la parte frontale del contenitore con un 
pezzo di cartoncino o con un panno, in modo da 
impedire alla luce di raggiungere gli occhi. 


COSTO DI REALIZZAZIONE LX.1183 

Il kit LX.1183 composto da una lampada lunga 30 
cm della potenza di 8 Watt, completa di Reattore, 
Starter Mammuth, Zoccoli mignon e di un cordone 
di rete completo di spina.€ 25,30 

NOTA: Questa è la lampada che utilizziamo nel no¬ 
stro laboratorio per cancellare le nostre Eprom e 
Microprocessori, perché con altre di potenza mi¬ 
nore non sempre riuscivamo a cancellarle. 



Fig.1 Su una piccola tavoletta in legno delle dimensioni di 12 x 47 cm abbiamo fissato a 
sinistra il reattore e a destra lo starter. Assieme alla lampada forniamo anche i due por¬ 
talampada miniatura che fisserete con viti in legno sulla tavoletta alla distanza richiesta. 
Nel disegno si nota chiaramente come dovete effettuare il semplice schema elettrico. 
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Fig.2 Sui due lati della tavoletta in legno abbiamo applicato due righelli alti circa 5,5 cm 
in modo da ottenere una distanza tra il bulbo della lampada ed il corpo superiore degli 
integrati (Eprom o Microprocessori cancellabili) che non risulti minore di 2 cm. Questa di¬ 
stanza non è critica, ma se superate i 4 cm dovrete aumentare i tempi d’esposizione. 
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